열혈강의 도전3-1 풀었는데 더 좋은방법있는지 궁금합니다.
소녀틳향기
소스의 간소화? 또는 더 좋은 알고리즘의 여부가 궁금해요.질문 내용 :
실행은 잘되는데 이렇게 질문드려도 되는지 모르겠습니다..
들여쓰기가 일일이 안되서 보시기 불편하신분 위해서 메모장 첨부해놨습니다.
처음에 문제보고 어떻게 풀어야할지 막막하다가
배열주소를 종이에 그리고 규칙성? 발견후 이런식으로 풀었는데요,
어떻게보면 진짜 무식하게 소스 짠거같기도 한데 더 좀더 소스의 고급화?라고할까요,,,
고수님들의 조언 기다리겠습니다./* 4x4 2차원배열 선언
1 2 3 4
5 6 7 8
9 10 11 12
13 14 15 16 초기화 하고 90%씩 회전시키는 프로그램 */
#include stdio.h
int main()
{
int arr[4][4] = {
1,2,3,4,
5,6,7,8,
9,10,11,12,
13,14,15,16
};
int i,j,k;
int temp[4][4];
for(i=0; i4; i++) {
for(j=0; j4; j++)
printf(%4d ,arr[i][j]);
printf(\n);
}
printf(\n);
for(i=0; i4; i++)
for(j=0; j4; j++)
temp[i][j] = arr[i][j];// 배열 복사
for(k=0; k3; k++) //90도 3번 회전 반복
{
for(i=0; i=3; i++)
arr[i][3] = temp[0][i];//1행 4열에 복사
for(i=0; i3; i++)
{
arr[3][i] = temp[3-i][3];//4열 4행에 복사
arr[i][0] = temp[3][i];//4행 1열에 복사
arr[0][i] = temp[3-i][0];//1행 1열에 복사
}//여기까지 바깥테두리 90도 회전
for(i=1; i=2; i++) {//위와 같은방식으로 작은 테두리 회전
arr[i][2] = temp[1][i];
arr[2][i] = temp[3-i][2];
arr[i][1] = temp[2][i];
}
for(i=0; i4; i++) {//출력문
for(j=0; j4; j++)
printf(%4d ,arr[i][j]);
printf(\n);
}
printf(\n);
for(i=0; i4; i++)
for(j=0; j4; j++)
temp[i][j] = arr[i][j];// 배열 복사
}
return 0;
}
-
키클
가능한 혼자서 풀어보려구 인터넷 다른분들 소스 참조는 안했었습니다,
구현방법만 생각하는데 한시간이 넘게걸렸네요...ㅜㅜ
다풀어놓구 다른분들 풀이법도 봤지만 이해 안되는는 부분들도 있어서 이렇게 글올립니다~