구현과 삼항연산자의 대한 질문.
#include <stdio.h>
void swap(int* xp, int* yp);
void printArray(int arr[], int size);
void selectionSort(int arr[], int n);
int main()
{
int arr[] = { 64, 25, 12, 22, 11,};
int n = sizeof(arr) / sizeof(arr[0]);
selectionSort(arr, n);
printArray(arr, n);
return 0;
}
void printArray(int arr[], int size)
{
for (int i = 0; i < size; i++)
printf("%d\n", arr[i]);
}
void swap(int* xp, int* yp)
{
int tmp = *xp;
*xp = *yp;
*yp = tmp;
}
void selectionSort(int arr[], int n)
{
for (int i = 0; i < n - 1; i++)
{
int* min_idx = &arr[i];
for (int j = i + 1; j < n; j++)
{
min_idx = (*min_idx < arr[j]) ? min_idx : &arr[j];
}
swap( min_idx, &arr[i]);
}
}선생님의 빈 칸 맞추기를 공개하시기 전에 문제를 생각하여 풀어봤습니다. 여러 숫자를 집어넣어봐도 잘되는 것 같습니다. 이 코드가 문제없이 잘 작동하는 코드일까요?
그리고 여기서 삼항연산자를 썼는데 삼항연산자가 자주 쓰이는 연산자 인가요?
답변 1
2
안녕하세요, 질문&답변 도우미 Soobak 입니다.
네, 삼항 연산자는 자주 사용되는 연산자 중 하나입니다.
간단한 조건문을 한 줄로 표현할 수 있도록 해주므로, 코드의 간결함 측면에서 장점이 있다고 생각합니다.
하지만, 복잡한 로직에서는 가독성을 해칠 수 있으므로, 상황과 환경에 따라서 적절히 선택하여 사용하시는 것이 좋은 것 같습니다.
또한, 일반적인 선택 정렬에서는 int min_idx = 인덱스 와 같이 '인덱스' 를 저장하여 풀이하게 되는데, 질문자님 스스로만의 방법으로 잘 구현하신 것도 인상 깊네요. 👍
Export template 안됨
1
19
2
완전히 똑같이 따라해도 exe파일이 안만들어져서 실행이 안됩니다.
1
54
3
main 함수에서 왜 int만 선언이 되는걸까요
1
56
2
8비트 2진수 변환시 왜 1을 더해야하나요?
1
54
2
혹시 강의를 빠르게 수강하려면 어디서부터 듣는게 좋을까요?
1
49
1
프로토타입과 함수간의 인자 불일치
1
73
2
12.12 헤더 관련 질문
1
60
2
Visual Studio Community 2026 사용 문의
1
137
2
Q. 15:30, 부호가 있는 8비트 정수 질문
1
61
2
getchar(), putchar()
1
93
3
강의자리ㅛ
1
80
2
비주얼스튜디오코드로 공부해도 상관없나요?
1
113
2
소스파일안에 여러 파일
1
76
2
F5와 F7의 차이
1
76
2
c = TWO * (a+b); 에서 a와 b는?
1
58
2
; 세미콜론을 붙이는 기준에 문의
1
69
1
Step over 기능 문의
1
53
2
2.6 강의 따옴표 출력 규칙 문의
1
74
2
int main 함수 관련 오류 문의
1
67
2
13.4 words[0]
0
61
2
11.7 함수를 구현해 봤습니다.
1
62
2
11.6 직접 strcmp와 strncmp를 구현해 보았습니다.
1
65
2
11.6 my_strcat과 my_strncat을 구현해봤습니다.
1
53
2
11.6 fit_str함수를 구현해 봤습니다.
1
53
2





