백준 11399 파이썬 삽입정렬 그리디

2024. 2. 19. 08:33코딩 도구/백준

반응형

백준 11399 - ATM

문제

https://www.acmicpc.net/problem/11399

 

11399번: ATM

첫째 줄에 사람의 수 N(1 ≤ N ≤ 1,000)이 주어진다. 둘째 줄에는 각 사람이 돈을 인출하는데 걸리는 시간 Pi가 주어진다. (1 ≤ Pi ≤ 1,000)

www.acmicpc.net

 

11399번

답안 코드 :

N = int(input())
A = list(map(int, input().split()))
S = [0]*N   # 합 배열

for i in range(1, N):    # 삽입 정렬
    insert_point = i
    insert_value = A[i]
    for j in range(i-1, -1, -1):
        if A[j] < A[i]:
            insert_point = j + 1
            break
        if j == 0:
            insert_point = 0
    for j in range(i, insert_point, -1):
        A[j] = A[j-1]
    A[insert_point] = insert_value

S[0] = A[0]

for i in range(1, N):    # 합 배열 만들기
    S[i] = S[i-1] + A[i]
sum = 0

for i in range(0, N):    # 합 배열 총합 구하기
    sum += S[i]
print(sum)

 

생각 :

# 문제 분석
# 그리디 방식
# 시간이 가장 적게 걸리는 사람 먼저 인출하도록 순서정하기!! -> 그리디
# N의 최대값이 1,000 그리고 시간제한 1초니까 n^2이하 알고리즘 아무거나 써서 정렬가능
# -> 삽입정렬 써봐야지.

# 문제 풀이
# 삽입 정렬 -> 오름차순 정렬
# 배열하고 합 배열 이용해서 계산.

# for j를 i-1~0까지 뒤에서부터 반복:
#     현재 범위에서 삽입 위치 찾기
# for j를 i~insert_point+1까지 뒤에서부터 반복:
#     삽입을 위해 삽입 위치에서 i까지 데이터를 한 칸씩 뒤로 밀기 
# 삽입 위치에 현재 데이터 저장

 

정렬알고리즘 정리

https://mkisos.tistory.com/entry/%EC%A0%95%EB%A0%AC-%EC%95%8C%EA%B3%A0%EB%A6%AC%EC%A6%98-%EB%B2%84%EB%B8%94-%EC%A0%95%EB%A0%AC-%EC%84%A0%ED%83%9D-%EC%A0%95%EB%A0%AC-%EC%82%BD%EC%9E%85-%EC%A0%95%EB%A0%AC-%ED%80%B5-%EC%A0%95%EB%A0%AC-%EB%B3%91%ED%95%A9-%EC%A0%95%EB%A0%AC-%EA%B8%B0%EC%88%98-%EC%A0%95%EB%A0%AC

 

반응형