inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

다차원 배열

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

해결된 질문

113

gloryovo

작성한 질문수 1

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;

}

 

감사합니다.

좋은 하루 보내세요 :)

c 컴퓨터-구조 assembly-language vc++

답변 1

1

널널한 개발자

사실 이 정도 예제는 성능을 논할 것이 많지 않습니다. 보통의 경우 알고리즘에서는 시간 복잡도 정도를 이야기 합니다. 아무튼...

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

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

119

3