예제를 풀었는데 이런 방법도 가능한지 피드백 부탁드립니다.
#include <stdio.h>
int main() {
int nArray[5][5] = { 0 };
int cnt = 0;
int tnt = cnt + 5;
for (int i = 0; i < 5 ; ++i)
{
if (i%2 == 0) // 짝수 홀수구분
for (int j = 0; j < 5; ++j)
{
nArray[i][j] = ++cnt;
}
else
for (int k = 4; k >= 0; --k) {
nArray[i][k] = ++cnt;
}
}
for (int i = 0; i < 5;++i)
{
for (int j = 0; j < 5; ++j)
{
printf("%d ", nArray[i][j]);
}
putchar('\n');
}
printf("%d", cnt);
return 0;
}
i값을 짝/홀 수로 분류하는 것 까지는 동일한데
열 부분을 보수 생각을 못하고 for문을 하나 더 돌려서
4에서부터 1씩 감소하는 방향으로 풀었는데
논리적으로 오류가 없을까요?
답변 2
0
안녕하세요, 인프런 AI 인턴입니다. uwkdwkdwkd님!
질문하신 코드를 보면, 5x5 배열에 숫자를 지그재그 형태로 채우는 예제를 잘 구현하신 것 같습니다. 각 행의 인덱스를 짝수와 홀수로 구분하여 다른 방향으로 값을 채우는 부분이 인상적입니다. 다음은 코드의 핵심 포인트와 관련된 설명입니다:
짝수/홀수 구분:
if (i%2 == 0)부분은 i가 짝수일 때 오른쪽으로, 홀수일 때 왼쪽으로 값을 채우는 역할을 합니다. 이는 배열을 지그재그로 채우는 데 적합한 방법입니다.지그재그 패턴 채우기: 홀수행의 경우
for (int k = 4; k >= 0; --k)를 사용하여 오른쪽에서 왼쪽으로 이동하며 배열을 채웁니다. 이러한 방식은 반복문을 하나 더 사용하는 것과 동일한 결과를 낼 수 있으며, 코드를 읽고 이해하기 쉽게 만듭니다.출력 확인 및 카운터: 마지막으로 배열을 출력하는 부분과 카운터
cnt의 최종값을 출력하는 부분도 적절합니다.
결론적으로, uwkdwkdwkd님의 코드에는 논리적인 오류가 없으며, 제대로 동작합니다. 이 방식은 명확하고, 지그재그 패턴을 구현하는 데 효율적입니다. 물론 배열을 다른 방법으로 채우는 방법도 가능하지만, 현재의 구현 방식도 충분히 직관적이며 목표를 잘 달성합니다.
관련 질문을 확인해 보세요: 필수 실습문제 '*' 출력놀이 응용 부분 관련 질문.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
scanf("%d\n") 의미
0
20
1
주소 연산자(&) 간접 지정자(*) 반대 개념
0
33
1
Virtual Memory, Memory, Memory mapping tables
0
51
1
샘플코드 출력 오류 발생 질문드립니다
0
63
2
값의 교환에 사용되는 변수의 위치.
0
88
2
메모리 비교에 관한 질문
0
81
2
문자열 Null
0
63
1
C, C++
0
88
2
문자열 입출력 코드 에러
0
60
2
선생님! 120화 2분 50초 질문입니다.
0
67
1
caller 가 메모리 할당 해제를 할 때의 문제점 질문
0
64
2
단축키 맞는지 여부 문의드립니다.
0
60
2
문자열을 사용하는 이중 포인터에 대하여 질문합니다
0
66
1
char 포인터 변수의 크기에 대하여 제가 이해한 것이 맞을까요
0
78
2
용어 설명 필요
0
57
2
stdin, stdout
0
71
2
필수 실습 (최댓값을 반환하는 함수)
0
93
2
아......ㅠㅠ
0
100
2
버퍼 내 엔터
0
72
1
2진수 뺄셈에서 carry-out
0
112
2
union 식별자는 실무에서 보통 어디에서 사용하나요?
0
80
2
필수실습문제 공부법 (진도 vs 복습)
0
104
2
예제파일 다운로드
0
79
2
Visial Studio Code 를 설치해서 사용해도 수업을 따라가는데 지장이 있나요?
0
120
3





