교안 이차원 배열 회전 질문드립니다.
84
작성한 질문수 24
교안 코드 중, resize()하는 코드가 있던데, 저의 코드는 resize()를 안해도 돌아가던데, resize()가 꼭 필요한가요?
key = temp는 key 변수에다가 temp의 주소값을 할당하므로 resize()가 필요없다고 생각합니다.
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
vector<vector<int>> v = {{1,2,3},{4,5,6},{7,8,9},{10,11,12}};
void left_90_rotate(vector<vector<int>> &key){
int n = key[0].size();
int m = key.size();
vector<vector<int>> temp(n, vector<int>(m,0));
for (int i = 0; i < n; i++){
for (int j = 0; j < m; j++){
temp[i][j] = key[j][i];
}
}
key = temp;
}
void rotate_90_right(vector<vector<int>> &key) {
int n = key[0].size();
int m = key.size();
vector<vector<int>> temp(n, vector<int>(m,0));
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
temp[i][j] = key[m-j-1][i];
}
}
key = temp;
}
void print_v(){
for (vector<int> tv : v){
for (int i : tv){
cout << i << " ";
}
cout << "\n";
}
cout << "--------------------\n";
}
int main(){
ios_base::sync_with_stdio(false);
cin.tie(0); cout.tie(0);
print_v();
left_90_rotate(v);
print_v();
rotate_90_right(v);
print_v();
}
답변 1
0
안녕하세요 동훈님 ㅎㅎ
1 2 3
4 5 6
7 8 9
10 11 12
--------------------
1 4 7 10
2 5 8 11
3 6 9 12
코드를 실행해보면 왼쪽으로 90도 돌리게 되면 앞처럼 나오게 되는데
3
2
1 ...
이런식으로 나와야 하는게 아닐까요?
확인부탁드립니다.
감사합니다.
0
수정했습니다!
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
vector<vector<int>> v = {{1,2,3},{4,5,6},{7,8,9},{10,11,12}};
void left_90_rotate(vector<vector<int>> &key){
int n = key[0].size();
int m = key.size();
vector<vector<int>> temp(n, vector<int>(m,0));
for (int i = 0; i < n; i++){
for (int j = 0; j < m; j++){
temp[i][j] = key[j][n-i-1];
}
}
key = temp;
}
void rotate_90_right(vector<vector<int>> &key) {
int n = key[0].size();
int m = key.size();
vector<vector<int>> temp(n, vector<int>(m,0));
for (int i = 0; i < n; i++) {
for (int j = 0; j < m; j++) {
temp[i][j] = key[m-j-1][i];
}
}
key = temp;
}
void print_v(){
for (vector<int> tv : v){
for (int i : tv){
cout << i << " ";
}
cout << "\n";
}
cout << "--------------------\n";
}
int main(){
ios_base::sync_with_stdio(false);
cin.tie(0); cout.tie(0);
print_v();
left_90_rotate(v);
print_v();
rotate_90_right(v);
print_v();
}
1
안녕하세요 동훈님 ㅎㅎ
코드 확인했으며
resize()는 필요없습니다. ㅎㅎ 동훈님 말씀이 맞습니다.
해당부분은 다음과 같이 수정되어 오늘 업로드 되었습니다.
#include <bits/stdc++.h>
using namespace std;
const int n = 3;
const int m = 4;
void rotate_left_90(vector<vector<int>> &key){
int n = key.size();
int m = key[0].size();
vector<vector<int>> temp(m, vector<int>(n, 0));
for(int i = 0; i < m; i++){
for(int j = 0; j < n; j++){
temp[i][j] = key[j][m - i - 1];
}
}
key = temp;
return;
}
void rotate_right_90(vector<vector<int>> &key){
int n = key.size();
int m = key[0].size();
vector<vector<int>> temp(m, vector<int>(n, 0));
for(int i = 0; i < m; i++){
for(int j = 0; j < n; j++){
temp[i][j] = key[n - j - 1][i];
}
}
key = temp;
return;
}
int main(){
ios::sync_with_stdio(0); cin.tie(0);
vector<vector<int>> a = {
{1, 2, 3, 4},
{5, 6, 7, 8},
{9, 10, 11, 12},
};
rotate_right_90(a);
for(int i = 0; i < m; i++){
for(int j = 0; j < n; j++){
cout << a[i][j] << " ";
}
cout << '\n';
}
return 0;
}
앞의 코드에서 key = temp를 볼까요?
C++에서 std::vector의 대입 연산자는 깊은 복사(deep copy)를 수행합니다. 이는 기존의 벡터 내부 메모리를 모두 해제한 후, 오른쪽 벡터의 모든 요소를 새로운 메모리 공간에 복사하기 때문에,key의 크기, 즉 행과 열의 수는 temp의 크기에 맞춰 자동으로 변경됩니다.
예리한 지적 감사합니다. ㅎㅎ
문제를 고민하는 시간 관련
0
13
2
코딩살구클럽
0
26
2
코딩살구클럽 문의
0
30
2
코딩살구클럽 승인
0
31
2
DP 경우의 수 설명이 이해가 되지 않습니다.
0
32
2
3-F 채점 관련 질문
0
29
1
BFS, DFS 활용이 되는 상황에서의 방향성
0
32
2
코딩살구클럽 승인
0
43
2
코딩살구클럽승인
0
39
3
코딩살구클럽 승인
0
51
2
3-D 관련 질문
0
35
2
코살구 회원가입 문의
0
45
2
코살구 로그인 문제
0
65
2
3-A 문제 풀이 관련 질문
0
56
3
2-O 질문 있습니다
0
38
2
2-T 문제에 관한 질문
0
40
2
코딩 살구 클럽 접속 및 사용방법 문의
0
63
2
안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~
0
64
2
코딩살구클럽 로그인문제
0
78
3
코딩 살구 클럽 로그인 문제
0
85
2
2-J 채점관련 질문
0
67
3
코딩 살구 클럽 Python 지원 가능 여부
0
77
1
살구클럽 아이디 없음 문제
0
76
1
1-O 코딩살구클럽 채점관련 질문
0
61
2





