질문입니다.
219
작성한 질문수 1
#include<stdio.h>
struct grade {
int num, math, eng, cLang;
};
int main(){
int n, i, tOrd, temp = 0;
scanf("%d", &n);
grade arr[n];
for(i=0; i<n; i++){
scanf("%d %d %d %d", &arr[i].num, &arr[i].math, &arr[i].eng, &arr[i].cLang);
if(temp < arr[i].math){
temp = arr[i].math;
tOrd = i;
}
}
printf("%d", arr[tOrd].cLang);
return 0;
}
번호와 성적은 한 줄에 입력받는데 왜 저렇게 따로 한줄한줄 scanf를 적어주는 건가요?
scanf("%d %d %d %d", &arr[i].num, &arr[i].math, &arr[i].eng, &arr[i].cLang);
이런식으로 적어도 문제는 없는지, 혹시 보통은 한줄씩 적는걸 선호하는건지 궁금합니다.
그리고 for문을 다시 돌리지 않고 입력받고 나서 바로 수학점수를 비교한 다음
i 변수를 임시로 tOrd 변수에 담아 출력하는 형식으로 짰는데요,
원래 따로 for문을 돌리는게 더 깔끔한 방법인건지 궁금합니다.
돌아는 가는데 보기좋지 않고 비효율적인 코드인걸까 궁금해요..!
답변 1
0
안녕하세요^^
입력은 아무렇게 받아도 상관없습니다.
원래는 입력받으면서 바로 구하는 위에 코드가 더 좋은 코드입니다.
기초단계의 강좌이다보니 제가 입력단계와 처리단계를 구분해서 설명하려고 그랬던게 아닌가 싶습니다.
음료수 자판기 출력이 이상하게 나옵니다
0
153
2
i 값 초기화 질문
0
79
2
recipe for targe 'AA.exe' failed
0
79
1
30과 10의 xor
0
203
1
커리큘럼 문의 드립니다
0
238
1
for문에서 sum 관련 질문
0
186
1
이렇게 풀어도 맞는걸까요?
0
262
2
이렇게 풀어도 맞는 풀이일까요?
0
308
1
20페이지 홀,짝,제로 문제에서 이 코드로 짜도 괜찮을까요?
0
270
1
24. 최솟값 구하기
0
342
1
질문 있습니다.
0
333
1
배열을 전역변수로 설정하는 이유
1
673
1
41. A를 #으로에서 질문 있습니다.
0
295
1
20번 소수 판별하기에서 질문 있습니다.
0
430
1
42번 bus error;;;
0
614
1
정수형 배열에서 배열 크기
0
401
1
38. 자리찾기 커지는 방향으로..
0
311
1
37. 배열의 회전에서 ...
0
286
1
1차원 배열에서
0
282
1
지수연산에서
0
307
1
7.연필 개수 문제
0
384
1
a=(int)a 에서 왜 괄호를 붙이나요 a=int a 는 왜안되나요
0
852
1
섹션 6. 소수
0
325
1
왜 2중for문을 두개 쓴건가요?
0
252
1





