해결된 질문
작성
·
89
0
안녕하세요.
강사님 강의 잘 듣고 있습니다. 좋은 강의에 먼저 감사 드립니다.
본 강의에서 int[5][5] 배열에 1 ~ 25 값을 입력하는 프로그램을 작성하는 중에 강사님께서는 for 문을 두 번 사용하여 작성하였고, 저는 for문을 1회 사용해서 과제를 수행했습니다.
전체 loop 횟수는 25회로 동일한 것으로 보이나 혹시 두 코드 간 속도 차이가 존재하는지 궁금합니다.
요즘 컴퓨팅 성능이 워낙 좋아 큰 문제는 되지 않겠지만 궁금증이 생겨서 질문 남깁니다.
아래는 제가 작성한 코드 입니다.
#include <stdio.h>
#include <stdlib.h>
int main(void)
{
int aList[5][5] = { 0 };
for (int i = 0; i < countof(aList) * countof(aList[0]); i++)
{
if (i != 0 && i % 5 == 0)
{
printf("\n");
}
printf("%2d ", aList[i / 5][i % 5]);
aList[i / 5][i % 5] = i + 1;
}
printf("\n");
for (int i = 0; i < countof(aList) * countof(aList[0]); i++)
{
if (i % 5 == 0)
{
printf("\n");
}
printf("%2d ", aList[i / 5][i % 5]);
}
return 0;
}
감사합니다.
좋은 하루 보내세요 :)
답변 1
1
사실 이 정도 예제는 성능을 논할 것이 많지 않습니다. 보통의 경우 알고리즘에서는 시간 복잡도 정도를 이야기 합니다. 아무튼...
보여주신 예제는 단일 for문으로 작성하기 위해 배열 인덱스 값을 계산하는 구조 입니다. 매우 잘 하신 것입니다. 의도적으로 문제를 어렵게 내려 할 때 취할 수 있는 것인데 직접 하신 경우입니다. 그러니 성능은 논하지 않는 것이 좋겠습니다. 😄