1차원 배열 출력
꽃봄
질문 제목 : 1차원 배열 출력질문 요약 :홀수가 먼저 나오고 그다음 짝수가 큰수부터 작은수로...
input 112233445566
ex)113355224466이런식으로...질문 내용 : 지금 배열의 순서도 문제를 풀고있습니다....
근데 여기서 배열이 들어가는 순서를 이해가 잘 안됩니다.
코드부분
#includestdio.h
#includestring.h
int main(void){
int arr[10];
int val[10];
int i;
int a;
int k=0;
int j=0;
int size=0;
printf(총 10개의 숫자 입력\n);
for(i=0;i10;i++){
printf(?: );
scanf(%d,&arr[i]);
}
size=sizeof(arr)/sizeof(int);
printf(\n);
for(i=0;isize;i++){
if(arr[i]%2!=0){
val[k]=arr[i];
k++;
}
else if(arr[i]%2==0){
val[size-j-1]=arr[i];
j++;
}
}
printf(배열 요소의 출력 );
for(i=0;isize;i++)
printf(%d ,val[i]);
return 0;
}
저기 빨간색 부분....
저부분이 짝수는 배열 뒤에서부터 차례대로 넣는건데....
size에서 -j를 해줌으로 맨 뒤에서 하나씩 들어가야하는데...제가 생각하기론 이론상으론...
근데 거기다 -1을 해줘야 입력한 값이 전부 출력이 되고 -1을 없이 size-j만 하니깐....
중간값이 쓰레기값이 나옵니다.....왜 -1을 해줘야 하나요.....
혹시 null때문에 무조건 -1을 해줘야 하는건가요?
그리고 추가로....113355664422 이런식으로 홀수먼저 나오고 짝수가 큰수부터 차례대로 내림차순은 어떻게 하면 될까요?
-
과꽃
그리고 해보지는 않았지만 내림차순으로 하실려면 지금 저 소스에서는 홀수와 짝수의 경계를 추가해줘야 할거 같습니다. 그 다음부터는 어떤 수가 큰지 작은지를 판단하여 그 위치를 바꿔주면 되겠네요. 여기서 경계는 몇번째 배열부터는 짝수다 라는거를 판단하는거에 사용됩니다.
만약 val[5]부터가 짝수라면은 0~4까지 내림차순 정렬을 시키고 5~9까지는 이제 그 범위 안에서만 내림차순 정렬을 시키는것입니다. -
핫자두
val[size-j-1]의 경우에는 배열의val[10]이면은 val[0]~val[9]까지이 이기때문에 저렇게 해놓은 것입니다.
지금 보니깐 홀수의 경우에는 앞에서부터 채워넣고 짝수의 경우에는 뒤어서부터 채워넣고 있네요.