inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

6.4 배열과 선택 정렬 selection sort

교수님이 해주신 Selection sort 반복문 중에 이해 안가는게 있습니다.

420

김승원

작성한 질문수 13

0

for (int currentIndex = startIndex + 1; currentIndex < length; ++currentIndex)

{

if (array[smallestIndex] > array[currentIndex])

{

smallestIndex = currentIndex;

}

}

    array[smallestIndex] = array[currentIndex]; 이 문장이 이렇게 되야 하지 않고

smallestIndex = currentIndex; 이렇게 해서 결과 값을 도출했는지 의아합니다.

교수님이 설명하신 swap기능은 이해가 가는데,

두 피연산자들을 비교할때 있는 smallestIndex = currentIndex; 이 부분은 잘 이해가 안갑니다..

C++

답변 3

1

logt

디버깅하면 알 수 있어요!

smallestIndex = currentIndex  는 말그대로 정수형 상수값을 current에서 small로 대입한 것이고,

array[smallestIndex] = array[currentIndex] 는 만약 small이 0이고 current가 1이라면 array[0]의 배열에 array[1]의 원소를 대입시킨 것이라 값이 다릅니다.

이미 질문자님을 알고 계시겠지만, 저를 위해서 남겨둬요!

0

김승원

for (int startIndex = 0; startIndex < length - 1; ++startIndex)

{

int smallestIndex = startIndex;

    for (int currentIndex = startIndex + 1; currentIndex < length; ++currentIndex)

{

if (array[smallestIndex] > array[currentIndex])

{

smallestIndex = currentIndex;

}

}

int temp = array[smallestIndex];

array[smallestIndex] = array[startIndex];

array[startIndex] = temp;

printArray(array, length);

}

교수님이 작성하신 Selection Sort 포문에서

for (int startIndex = 0; startIndex < length - 1; ++startIndex)

{

int smallestIndex = startIndex;

    for (int currentIndex = startIndex + 1; currentIndex < length; ++currentIndex)

{

if (array[smallestIndex] > array[currentIndex])

{

array[smallestIndex] = array[currentIndex];

}

}

int temp = array[smallestIndex];

array[smallestIndex] = array[startIndex];

array[startIndex] = temp;

printArray(array, length);

}

이런 식으로 작성해봣는데 결과값이 이상하게 떠서요... 왜그런지 잘 모르겠습니다..

array[smallestIndex] = array[currentIndex];

smallestIndex = currentIndex;

이 두개의 차이점이 뭔지 잘 모르겠습니다..

0

홍정모

어떻게 이해가 안가시는를 적어주셨으면 조금 더 구체적으로 도와드릴 수 있겠지만, 일단 일반적인 말씀을 드리자면 array에서 가장 작은 값을 갖는 index를 추적하기 위해서 유지하는 부분인데, 최소값이나 최대값 찾을 때 많이 사용합니다. 원 교재의 해당 부분 링크도 남깁니다. 그 외에 selection sort관련된 동영상 등을 찾아보시는 것도 도움이 될겁니다. 보통 정렬은 자료구조 과목에서 자세히 배웁니다.

https://www.learncpp.com/cpp-tutorial/64-sorting-an-array-using-selection-sort/

변수가 메모리에 저장되는 것을 알려주는 강의가 어떤강의였죠

1

464

1

메모리 주소 10진수로 출력

1

653

1

클래스 템플릿 특수화에서 boolalpha로 표현된 리턴값에 대해 질문이 있습니다.

1

498

1

여러가지 리턴 타입에 관한 강의가 어떤 걸까요?

1

534

1

메모리 주소에 관한 질분

0

679

1

인터페이스 클래스에서 reportError의 매개변수에 대해 궁금한 것이 있습니다.

0

549

1

형변환 오버로딩에서 const 관련 질문이 있습니다.

0

443

1

Digit 뒤에 reference를 사용하는 이유

0

509

1

4.2 전역 변수, 정적 변수, 내부 연결, 외부 연결

0

322

1

dat파일이...

0

538

1

TODO:대입 연산자 오버로딩에 대한 소스코드입니다.

0

643

1

복사 생성자 관련 질문이 있습니다.

0

454

1

수업 중 궁금한점이 있습니다.

1

389

1

라이브러리자체가 이해가 되지 않습니다.

0

561

1

마지막 예제 질문

0

302

1

증감연산자 위치에 따른 수행 순서 질문입니다.

0

374

1

단항 연산자 오버로딩에서 return 부분에 질문이 있습니다.

1

410

1

friend함수 관련 질문이 있습니다.

0

311

1

operator+ 정의부분에서 궁금한 것이 있습니다.

0

447

1

3분 17초 질문

0

350

1

함수에 값을 대입한다는 개념이 이해가 되지 않습니다.

0

446

1

int getvalue() const에서 const는 왜 뒤에 붙는건가요?

0

443

2

const Something &st에서 const를 빼면 안되나요?

0

300

1

friend함수는 다른 클래스의 멤버함수로 쓸 수 없나요??

1

492

1