백준 - 단계별로 풀어보기/2차원 배열

1. 문제 상세 https://www.acmicpc.net/problem/2563 2. 문제 접근 크기가 100*100인 정수 배열을 선언하여 색종이가 덮이지 않은 부분을 0, 덮인 부분을 1로 판단하자. 색종이의 개수를 입력받아 그만큼 반복문을 실행한다. 반복문에서 도화지에 색종이를 놓을 좌표를 입력받는다.값에 3, 7을 입력 받은 경우, 배열의 7번 행 3번 열부터 부터 이를 기준으로 16번행, 7번행 까지 사각형으로 배열의 원소들을 1로 바꾼다.위와 같이 좌표에 따라 배열의 원소 값을 바꿔준 후, 배열을 순회하며 배열의 값이 1인 경우, 넓이를 저장할 변수에 1을 더해주자. 3. 문제 풀이 #include using namespace std; int main() { int a[100][100] = ..
1. 문제 상세 https://www.acmicpc.net/problem/10798 2. 문제 접근 최대 15*5 크기의 행렬을 입력받고, 이 행렬의 원소들을 열의 1행, 2행, .. 5행, 2열의 1행, 2행, ..5행 과 같이 출력하자. 기존에 행렬을 출력할때는 행-열 순으로 출력했는데 이번에는 열-행 순으로 출력하자. 그리고, 15*5 크기의 행렬에서 입력받지 않은 부분은 출력하지 않도록 한다. char형 배열 선언 시 배열에 기본으로 '\0' 값이 저장된다. 따라서 출력에서 문자가 '\0' 인지 확인하고 출력한다. (여기서 주의할 점★, char 배열을 지역변수로 선언 시 자동 초기화가 되지 않아 기본 값으로 이상한 값들이 들어간다. 따라서 선언할 때 전역변수로 선언하거나 배열을 배열[n][m] ..
1. 문제 상세 https://www.acmicpc.net/problem/2566 2. 문제 접근 행렬을 돌며 값을 비교해 최대값 변수에 저장하고, 저장할 때 해당 배열의 인덱스를 저장하자. 모든 정수를 비교했다면 최대값과 저장해둔 인덱스 번호에 1을 더한 값을 출력한다. 3. 문제 풀이 #include using namespace std; int main() { int a[9][9], max = 0, row, col; for(int i = 0; i > a[i][j]; for(int i = 0; i = max) { max = a[i][j..
1. 문제 상세 https://www.acmicpc.net/problem/2738 2. 문제 접근 N*M 크기의 행렬을 입력받아 행렬의 원소의 값을 더해 출력하자. N 과 M 은 100 이하이므로 2차원 배열의 크기는 100*100 으로 선언한다. N 과 M 을 첫째 줄에 입력받는다. 한 줄에 정수 M 개를 N 줄 입력받도록 반복하고, 이를 두 번 반복한다. 이제 두 행렬에서 각 원소들의 값을 더하고 행렬을 출력하자. 3. 문제 풀이 #include using namespace std; int main() { int a[100][100], b[100][100], n, m; cin >> n >> m; for(int i = 0; i ..
Dry_p
'백준 - 단계별로 풀어보기/2차원 배열' 카테고리의 글 목록