
제일 처음에는 재귀를 이용하여 문제를 풀었다. 그러나 재귀함수를 이용할 경우 반복되는 연산이 많아 시간초과가 뜬다. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 # 재귀호출 ver import sys num_of_stairs = int(input()) stairs = [] for _ in range(num_of_stairs): stairs.append(int(sys.stdin.readline().strip())) # s_n = s_n-1 + a_n or s_n-2 + a_n def climbing(n, two_step): # two_step은 이전 계단에서 2칸 이동했는지 확인 if n

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 # pypy3로 제출해야 시간초과가 나지 않습니다. sudoku = [] for _ in range(9): sudoku.append(list(map(int, input().split()))) def print_sudoku(sudoku): for line in sudoku: print(*line) print() def check_sudoku(i,j, candidate): global sudoku # 세로 체크 for x in range(9): if sudok..

1234567891011121314151617181920import sys num = int(input())meeting_list = []for case in range(num): meeting_list.append(list(map(int, sys.stdin.readline().strip().split()))) # 회의가 끝나는 시간이 빠른 순으로 재정렬meeting_list = sorted(meeting_list, key=lambda x: (x[1],x[0])) post_meeting = [0, 0]count = 0for meeting in meeting_list: if post_meeting[1] > meeting[0]: pass else: count += 1 post_meeting = [meetin..

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 import sys num, target = list(map(int,(input().split()))) coin_list = [] for case in range(num): coin_list.append(int(sys.stdin.readline().strip())) total = 0 count = 0 for coin in coin_list[::-1]: if coin > target or coin + total > target: pass else: temp = (target-total)//coin total += temp * coin count += temp if total == target: print(count) br..

최초의 프로그램은 검색창(input)에 입력된 내용을 를 이용해서 /Profile에 정보를 넘겼다. 그러나 이 방법은 오로지 클릭만으로 동작된다. 우리가 일반적으로 검색창에 내용을 입력한 뒤 엔터키를 누르면 자동으로 페이지가 넘어가는 방식은 불가능 한 것 같다.(꽤 많이 찾아봤지만 해결하지 못 했다... 물론 방법이 있을수도) 그래서 결국 URL에 parameter를 추가하여 직접적으로 정보를 받을 수 있게 했다. 보안이 필요한 정보라면 이 방법이 위험할 수 있지만 현재는 검색내용만을 받으면 되므로 괜찮을 것 같다. URL 주소로 parameter를 전송하기 위해선 App.js의 path에 '/:' + 'parameter 이름'을 추가한다. window.location.href로 원하는 주소로 redir..

123456789101112131415161718192021import sys test_case = int(input())triangle = []result = [[] for _ in range(test_case)]for case in range(test_case): if case == 0: # 제일 상단 값 집어 넣기 top = int(input()) triangle.append([top]) result[case].append(top) else: triangle.append(list(map(int, sys.stdin.readline().split()))) for i in range(case+1): if i == 0: # 제일 좌측일 경우 result[case].append(triangle[case][i..

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 import sys test_case = int(input()) result_list = [[] for _ in range(test_case)] for case in range(test_case): R, G, B = map(int,sys.stdin.readline().strip().split()) if case == 0: result_list[0].append(R) result_list[0].append(G) result_list[0].append(B) else: result_list[case].append(R + min(result_list[case - 1][1], result_list[case - 1][2])) result_list..
- Total
- Today
- Yesterday
- 리액트 동작원리
- 프론트
- 리액트 리덕스
- 파이썬
- 리액트 jsx
- 해쉬 라우터
- 리액트 리스트 key
- props를 변경하지 못하는 이유
- Hash Router
- 댓글 모듈
- 리덕스 썽크
- 인사이트
- props를 변경하지 않는 이유
- 리액트 리스트 키
- 리액트 props
- localhost https
- React key
- mkcert
- 우테코
- 다라쓰
- 백준
- Python
- contentEditable focus
- 프론트엔드
- 브라우저 라우터
- Browser Router
- 리액트 키
- Redux Thunk
- 1463
- 우아한테크코스
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | ||||||
2 | 3 | 4 | 5 | 6 | 7 | 8 |
9 | 10 | 11 | 12 | 13 | 14 | 15 |
16 | 17 | 18 | 19 | 20 | 21 | 22 |
23 | 24 | 25 | 26 | 27 | 28 | 29 |
30 | 31 |