선택정렬
void printArray(int array[], int length)
{
for (int index = 0; index < length; ++index)
{
cout << array[index];
}
cout<<endl;
}
int main()
{
int arr[] = { 3,5,2,1,4 };
printArray(arr, 5);
for (int i = 0; i < 4; i++)
{
int smallest_index = i;
for (int current_index = i + 1; current_index <5; current_index++)
{
arr[smallest_index] = (arr[smallest_index]>arr[current_index]) ? arr[current_index] : arr[smallest_index];
}
int temp = arr[smallest_index];
arr[smallest_index] = arr[i];
arr[i] = temp;
printArray(arr, 5);
}
}
다음 코드를 실행하면 제대로 된 오름차순 형태의 선택 정렬이 나타나지 않고
35214
15214
11214
11114
11114
이렇게 나옵니다. 숫자가 swap되는 부분이 잘못된 것 같은데 어느 부분을 고쳐야 할까요?
답변 1
1
안녕하세요, 답변 도우미 Soobak 입니다.
반복문에서 최소값을 탐색하고 교환하는 부분에 문제가 있습니다.
작성하신 코드에서는 최소값 탐색 과정 중 계속해서 arr[smallest_index] 의 값을 직접 변경하고 있습니다.
따라서, 배열의 원래 값을 잃어버리게 됩니다.
smallest_index 변수에 최소 값의 인덱스만 저장하고, 배열의 값은 최소 값의 인덱스를 찾은 후에 해당 인덱스의 값을 현재 인덱스 i 의 값과 교환하는 방향으로 작성해보시면 좋을 것 같습니다.
예시 )
for (int i = 0; i < length - 1; i++)
{
int smallest_index = i;
for (int current_index = i + 1; current_index < length; current_index++)
{
if (arr[current_index] < arr[smallest_index])
smallest_index = current_index;
}
if (smallest_index != i)
{
int temp = arr[smallest_index];
arr[smallest_index] = arr[i];
arr[i] = temp;
}
}
강의자료는 어디서 받을 수 있죠?
1
20
2
교재 있나요?
1
138
2
11:11 부근에 Something::temp와 Something::getValue의 앞에 &를 붙이는 이유가 뭔가요? (함수 이름은 포인터(주소)가 아닌가요?)
1
91
3
using namespace std; 선언 후에 std::를 하는 이유가 궁금합니다
1
102
2
cstr직접구현
0
116
3
BubbleSort
1
78
2
숙제 마지막 부분
1
79
2
강의와 똑같이 진행했는데 링킹 에러가 발생합니다.
1
95
2
수업할때 레퍼런스로 사용하는 도서는 어떤 도서인가요??
1
164
2
공변반환형 관련 문의 드립니다.
1
90
2
170강 유니크 포인터에대해 질문있습니다
1
81
1
섹션 5 퀴즈의 답이 이상합니다
1
84
2
이중포인터와 배열이 이해가 안됩니다.
1
159
2
5분 17~5분 34초 객체 잘림 질문
1
79
1
Resource.h 코드 알려주세요
1
72
1
char name[] 배열의 길이와 관련해 일부 궁금점이 생겨서 질문합니다
1
94
2
화면좌측 숫자 보이기
1
115
1
화면 좌측 숫자 보이기
0
67
1
처음 c++ 수강하려는데요. 비주얼스튜디오 2022 다운로드해서 설치하면 되는건가요??
1
138
3
46강 string 버퍼 질문입니다
1
81
2
프로그래머스 수열과 구간 쿼리 2 문제 질문입니다.
1
124
2
[] 범위 검사시 assert 사용 관련 질문
1
90
2
Lecture 클래스 멤버변수 명명 관련
0
92
2
프로그래머스의 대소문자 바꿔서 출력하기 문제를 푸는데요
0
74
1





