강의

멘토링

로드맵

Inflearn brand logo image

인프런 커뮤니티 질문&답변

gloryovo님의 프로필 이미지
gloryovo

작성한 질문수

독하게 시작하는 C 프로그래밍

다차원 배열

int[5][5] 배열 실습 과제 관련 질문

해결된 질문

작성

·

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문으로 작성하기 위해 배열 인덱스 값을 계산하는 구조 입니다. 매우 잘 하신 것입니다. 의도적으로 문제를 어렵게 내려 할 때 취할 수 있는 것인데 직접 하신 경우입니다. 그러니 성능은 논하지 않는 것이 좋겠습니다. 😄

gloryovo님의 프로필 이미지
gloryovo

작성한 질문수

질문하기