find_set과 union을 사용하는 문제! 각 노드마다 부모를 가리키키는 리스트를 만들어주고 union연산을 통해 두 집합을 통합시킨다. 뒤에 오는 인자(y)가 부모노드가 된다. 여기서 find_set연산을 하는데, 노드X가 부모노드값과 같으면 노드 x값이 리턴이 되고 아니라면 다시 find_set함수로 들어가서 부모노드를 찾아 리턴시켜준다. 예시로 union(1,2)을 보면 parent =[0,1,2] 이다. parent[find_set(2)] = find_set(1) find_set(2)은 if 2 == parent[2]: return 2 대입하면 union(1,2): parent[2] = find_set(1) 이 되고 find_set(1)은 리턴 1이므로 parent[2] = 1이 되어 pare..
상호배타 집합: 서로 중복하게 포함된 원소가 없는 집합들을 뜻한다. 집합에 특정한 멤버를 대표자라고 하며 각 집합을 구분한다. 상호배타집합 표현방법 => 연결리스트, 트리 연결리스트 1.같은 집합의 원소들은 하나의 연결리스트로 관리 2.맨 앞의 원소가 대표원소 3. 각 원소는 대표를 가리키는 링크를 갖음 트리 1. 하나의 잡합을 하나의 트리 2. 자식노드는 부모노드를 가리킨다. 따라서 가장 상위에 있는 루트 노드가 대표자가 된다. 연산 Make-Set(x) :멤버x만 포함하는 새로운 집합을 생성 Find-Set(x) :원소 x가 속한 집합을 알아내기 위함, 대표자를 알아내기 위함 Union(x,y) : x가 속한 집합과 y가 속한 집합을 하나의 집합으로 합침 연산의 효율을 높이는 방법 1. union에서..
최소 몇 번의 연산을 거쳐야 하는지 알아내는 프로그램이기 때문에 BFS로 푸는 문제이다. deque를 사용해야 시간초과가 생기지 않는 다는 점을 알게 된 문제였다. 그리고 2+1 =3 , 3-1 =2가 반복하여 생길 수 가 있는데 이러한 문제를 예방하기 위해서 연산 결과 숫자를 인덱스로하는 리스트로 visited를 사용했고 방문했다고 처리해줬다. from collections import deque # 연산: +1, -1, *2, -10 네 가지 # 큐에 숫자연산결과와 횟수 함께 넣기 def oper(): global result while Q: #큐가 비어있지 않으면 front, check = Q.popleft() if front == M: result = check return #함수 종료 for i..
def dfs(): if len(s) == M: print(' '.join(map(str,s))) return for i in range(1, N+1): if i in s: # 가지치기, 이미 선택한 숫자 배제 continue if len(s) > 0: #리스트 안에 존재할 때 if s[-1] > i: #맨 끝 원소가 i보다 작을 때는 넘겨버린다.(오름차순 만들기 위함) continue s.append(i) dfs() #함수호출 s.pop() # 출력 후 return하고 마지막 원소 비우기 N, M = map(int, input().split()) s = [] dfs()
입력 값이 3 5 7 12 라면 무게가 가장 많이 나가는 값은 해당하는 하나의 로프에만 가능하고 가장 작은 무게를 가진 로프는 모든 로프의 개수에 가능 하기 때문에 내림차순 정렬을 해서 인덱스 간의 곱으로 풀이를 했다. 따라서 먼저 sort()함수를 사용하여 오름차순 정렬을 한 다음에 reverse()함수를 사용하여 내림차순으로 정렬을 했다. 그러면 rope = [12, 7, 5]가 되는데, 리스트 인덱스는 0부터 시작하기 때문에 인덱스+1를 해준 값을 각 원소마다 곱해주었다. 이 곱해준 값들을 다 저장해 놓고 최대값을 뽑으면 된다. N = int(input()) rope = [] for i in range(N): rope.append(int(input())) rope.sort() rope.reverse..
1. 일단 모든 조합의 합을 구해서 B보다 같거나 큰것이 있다면 리스트에 넣어준다. 2. 리스트에서 가장 작은 값을 추출하여 B에서 뺀다. from itertools import combinations T = int(input()) #높이가 B 이상인 탑 중에서 높이가 가장 낮은 탑 #조합을 구하여 합이 B보다 큰것의 리스트를 만든다. for tc in range(1,T+1): N, B = map(int,input().split()) # N:점원 수 B:선반의 높이 H = list(map(int,input().split())) over = [] sum_o = [] for i in range(N+1): over.append(list(combinations(H,i))) for j in range(len(ov..
1.거꾸로 봐서 현재보다 큰 것이 있다면 M 갱신. 2. 큰 것이 없다면 M에서 빼준 값을 누적 합을 구해주기 *****이 문제는 SWEA에 있는 1859번 백만장자 프로젝트 문제와 같은 문제이다***** T = int(input()) for tc in range(T): N = int(input()) lst = list(map(int, input().split())) lst.reverse() #거꾸로 보기 M = lst[0] ans = 0 for i in range(len(lst)): if M >= lst[i]: ans += M - lst[i] else: M = lst[i] # 큰게 있다면 최고가 갱신 print(ans) 런타임에러 난 코드(인덱스 에러) ##########런타임에러######### T ..
- Total
- Today
- Yesterday
- 배포
- git
- 안드로이드스튜디오
- javascript
- 트리
- Python
- Pyhton
- AWS
- 위클리챌린지2주차
- SQL
- Java
- SSAFY퇴소
- DOM
- vue
- 비동기패턴
- 자바
- 싸피
- 독학
- N과M
- commit되돌리기
- 세션 스토리지
- 알고리즘
- SSAFY
- 백준
- django
- splide
- 프로그래머스
- vue.js
- SWEA
- 파이썬
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |