선택정렬
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
53
2
교재 있나요?
1
163
2
11:11 부근에 Something::temp와 Something::getValue의 앞에 &를 붙이는 이유가 뭔가요? (함수 이름은 포인터(주소)가 아닌가요?)
1
112
3
using namespace std; 선언 후에 std::를 하는 이유가 궁금합니다
1
121
2
cstr직접구현
0
136
3
BubbleSort
1
84
2
숙제 마지막 부분
1
84
2
강의와 똑같이 진행했는데 링킹 에러가 발생합니다.
1
103
2
수업할때 레퍼런스로 사용하는 도서는 어떤 도서인가요??
1
177
2
공변반환형 관련 문의 드립니다.
1
96
2
170강 유니크 포인터에대해 질문있습니다
1
94
1
섹션 5 퀴즈의 답이 이상합니다
1
91
2
이중포인터와 배열이 이해가 안됩니다.
1
174
2
5분 17~5분 34초 객체 잘림 질문
1
83
1
Resource.h 코드 알려주세요
1
77
1
char name[] 배열의 길이와 관련해 일부 궁금점이 생겨서 질문합니다
1
102
2
화면좌측 숫자 보이기
1
122
1
화면 좌측 숫자 보이기
0
72
1
처음 c++ 수강하려는데요. 비주얼스튜디오 2022 다운로드해서 설치하면 되는건가요??
1
148
3
46강 string 버퍼 질문입니다
1
88
2
프로그래머스 수열과 구간 쿼리 2 문제 질문입니다.
1
130
2
[] 범위 검사시 assert 사용 관련 질문
1
97
2
Lecture 클래스 멤버변수 명명 관련
0
100
2
프로그래머스의 대소문자 바꿔서 출력하기 문제를 푸는데요
0
80
1





