inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

홍정모의 따라하며 배우는 C++

선택정렬

해결된 질문

231

geoni6877

작성한 질문수 2

1

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되는 부분이 잘못된 것 같은데 어느 부분을 고쳐야 할까요?

c++

답변 1

1

Soobak

안녕하세요, 답변 도우미 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