필요(96)
-
[백준/C++]#1991 - 트리 순회
풀이 #include using namespace std; int a[50][2]; void preorder (int N) { if (N == -1) return; cout x >> y >> z;// 알파벳 입력 x = x-'A';// 문자 -> 숫자 변환 if (y == '.') {// 입력이 .이면 그 자리에 -1 대입 a[x][0] = -1; } else { a[x][0] = y-'A'; } if(z == '.') { a[x][1] = -1; } else { a[x][1] = z-'A'; } } preorder(0); cout 오른쪽 중위 : 왼쪽->노드->오른쪽 후위 : 왼쪽->오른쪽->노드 덩어리처럼(서브트리) 생각해서 접근하면 순회 순서를 생각하기가 쉬워진다. 문자를 숫자로, 숫자를 문자로 바..
2021.02.16 -
[백준/C++]#2146 - 다리 만들기
풀이 #include #include using namespace std; int N; int a[101][101]; int g[101][101]; int d[101][101]; int dx[] = {1, 0, -1, 0}; int dy[] = {0, 1, 0, -1}; int main() { scanf("%d", &N); for (int i=0; i
2021.02.15 -
[백준/C++]#7576 - 토마토
풀이 #include #include using namespace std; int N, M; int a[1001][1001]; int ck[1001][1001]; int dx[] = {1, 0, -1, 0}; int dy[] = {0, 1, 0, -1}; int main() { queue q;// pair 받는 큐 선언 scanf("%d %d", &M, &N); for (int i=0; i
2021.02.13 -
[백준/C++]#2178 - 미로 탐색
풀이 #include #include using namespace std; int N, M; int a[101][101]; int ck[101][101]; int dx[] = {1, 0, -1, 0}; int dy[] = {0, 1, 0, -1}; int main() { scanf("%d %d", &N, &M); for (int i=0; i
2021.02.11 -
[백준/C++]#4963 - 섬의 개수
풀이 #include using namespace std; int a[51][51]; bool ck[51][51]; int dx[] = {-1, -1, -1, 0, 0, 1, 1, 1};//상하좌우 대각 int dy[] = {-1, 0, 1, -1, 1, -1, 0, 1}; int w,h; void dfs(int y, int x, int CNT) { ck[y][x] = true; for (int k=0; k> h && (w!=0 && h!=0)) {// w와 h가 모두 0이면 종료 for (int i=0; i a[i][j];// 입력 ck[i][j] = false;// ck 배열 초기화 } } int cnt=0; for (int i=0; i
2021.02.10 -
[전공필수] 신호 및 시스템 리뷰
신호 및 시스템 과목에서는 푸리에, 라플라스 변환의 활용적인 측면을 배운다. 이전에 배운 공업수학과 연계되며, 이는 통신관련 과목으로 이어진다. 특정 목적을 위해 신호를 시스템에 대입해 다른 신호로 변환한다. 그러한 과정을 알아보는 과목이다. 기본적으로 공업수학에서 배운 복소수가 아주 많이 사용된다. 일단 신호는 CT(continous-time)와 DT(discrete-time) 신호로 나뉜다. 전자는 현실에 존재하며, 시간에 따라 무한한 값이 존재하므로 컴퓨터가 사용할 수 없다. 후자는 현실에는 없지만, 주로 가공된 값으로 컴퓨터가 여러 계산을 위해 사용할 수 있다. 현실의 CT를 DT로 변환하고, DT를 통해 컴퓨터에서 정보를 사용한 뒤, 다시 DT를 CT로 변환해 유의미한 값을 제공한다. 또한 CT..
2021.02.09 -
[백준/C++]#2667 - 단지번호붙이기
풀이 #include #include using namespace std; int a[26][26]; int check[26][26]; int dx[] = {0, 0, 1, -1};// 상하좌우 + 1 int dy[] = {1, -1, 0, 0}; int ans[25*25]; int n; void dfs(int x, int y, int CNT) { check[x][y] = CNT; for (int k=0; k
2021.02.09 -
[백준/C++]#9466 - 텀 프로젝트
풀이 #include using namespace std; int a[100001]; int check[100001]; int numb[100001]; int dfs(int node, int len, int num) { if (check[node] != 0) {// 사이클의 시작부분일 때 if (num != numb[node]) {// 지금 고유번호와, 사이클 고유번호가 다르면 return 0; } else return len-check[node];// 사이클 길이 출력 } check[node] = len;// 길이 대입 numb[node] = num;// 고유번호 대입 return dfs(a[node], len+1, num);// 탐색 순환 } int main() { int t; cin >> t; wh..
2021.02.09 -
[백준/C++]#2331 - 반복수열
풀이 #include #include #include #include using namespace std; pair a[300000]; bool check[300000]; int cnt = 0; void dfs(string N, int P) { int node = std::stoi(N);// 문자열 -> 정수 check[node] = true; int findNext = 0;// 다음에 연결되는 노드 계산 for (int i=0; i 문자열 dfs(nextS, P); } else { cout > n >> p; dfs(n, p); return 0; } 개념 문자열을 숫자로 바꾸고, 숫자를 문자로 바꾸는데 string 라이브러리가 사용된다. std::stoi (문자열 -> 숫자), std::to_string..
2021.02.07