목록코테준비 (91)
JiSoo's Devlog
import sys def roundup(num): if(num - int(num)) >= 0.5: return int(num) + 1 else: return int(num) n = int(sys.stdin.readline()) if n == 0: print(0) else: a = [] for i in range(n): a.append((int(sys.stdin.readline()))) a.sort() b = roundup(n*0.15) print(roundup(sum(a[b:n-b])/len(a[b:n-b]))) 의견이 없는 경우 난이도 0인 것을 고려한다 유의할 점은 round 함수를 쓰면 안 된다 - 사사오입의 원칙 때문(5에서 반올림할 때 앞자리가 홀수면 올림, 짝수면 내림) 슬라이싱을 위해 정렬..
n = int(input()) s = [] a = [] f = 0 c = 1 for i in range(n): num = int(input()) while c
n = int(input()) r = 0 for i in range(1, n+1): a = list(map(int, str(i))) r = sum(a) + i if r == n: print(i) break if i == n : print(0) 216 = 198 + 1 + 9 + 8 여기서 198이 가장 작은 분해합 브루트포스 알고리즘 사용 1부터 시작해 가장 작은 생성자 찾으면 탈출 정수의 각 자릿수를 리스트로 받기 위해 map함수 사용하고 각 자릿수 값을 int로 형변환 예를 들어 245를 입력받았다면 리스트 a는 [2, 4, 5]가 된다 분해합과 입력값이 같으면 그 분해합은 생성자이기 때문에 탈출해 그 값 출력
import sys from collections import Counter n = int(sys.stdin.readline()) a = [] for i in range(n): a.append(int(sys.stdin.readline())) def mean(num): return round(sum(num)/len(num)) def median(num): num.sort() mid = num[len(num)//2] return mid def mode(num): d = Counter(num) k = d.most_common() if len(num) > 1: if k[0][1] == k[1][1]: mod = k[1][0] else: mod = k[0][0] else: mod = k[0][0] return m..
t = int(input()) for i in range(t): k = int(input()) n = int(input()) p = [i for i in range(1, n+1)] # 0층 for j in range(k): for c in range(1, n): p[c] += p[c-1] print(p[-1]) 호수별로 늘어나는 규칙성이 없어 0층부터 구할 층수까지 사람 수 더해가는 방식 0층에서 1호부터 입력받은 호수까지 사람 수 리스트 생성 입력받은 층수만큼 for문을 반복하고 중첩 for문으로 1호부터 입력받은 호수까지 반복 층수가 증가할 때마다 한층 아래의 이전 호실에 사는 사람의 수를 더해준다 반복문이 끝났을 때 가장 마지막 수가 해당하는 층, 호수에 사는 사람의 수
n = int(input()) a = [] for i in range(n): m = int(input()) if m == 0: a.pop() else: a.append(m) r = sum(a) print(r) 수를 잘못 불렀을 때 0을 외친다고 했으니까 0을 불렀다면 최근 수 지우기 0이 나오면 pop()으로 리스트에 들어있던 수 빼주고 아니면 append
while(1): n = input() s = [] if n == '.': break for i in n: if i == '[' or i == '(': s.append(i) elif i == ']': if len(s) != 0 and s[-1] == '[': s.pop() else: s.append(']') break elif i == ')': if len(s) != 0 and s[-1] == '(': s.pop() else: s.append(')') break if len(s) == 0: print('yes') else: print('no') 스택 사용하기 스택 리스트를 만들어서 먼저 들어온 괄호 저장하고 짝 맞는 괄호 들어오면 pop으로 리스트 비워주기 짝이 맞지 않는 게 들어오면 그대로 두기 스택 ..
n = int(input()) a = [] for i in range(n): x, y = map(int,input().split()) a.append([y, x]) n = sorted(a) for y, x in n: print(x, y) x, y를 map으로 받고 y 기준으로 정렬될 수 있게 [y, x]로 append sorted 함수로 정렬
from collections import deque n = int(input()) q = deque() for i in range(1, n+1): q.append(i) while(len(q)!=1): q.popleft() q.append(q.popleft()) print(q[0]) 큐에 1부터 n까지 넣어주고 큐에 남은 숫자가 1개가 될 때까지 반복 popleft()로 제일 위의 카드 버리고 그다음 제일 위의 카드를 뽑아서 밑에 추가