inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

6.4 배열과 선택 정렬 selection sort

이해안가는 부분 질문있습니다

211

vpemflrkql0926

작성한 질문수 4

0

앞 강의에서 최대 최소 구할때 하나하나씩 비교하는 것이랑

이번 선택정렬에서 하나씩 비교하는 것이랑 어떻게 다른건가요?

 

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

for (int j = i + 1; j < length; j++) {

if (arr[i] > arr[j]) { // ? 

int temp = arr[j]; 

arr[j] = arr[i];

arr[i] = temp;

}

}

printArr(arr, length);

}

여기서 if(arr[i] > arr[j]) 하는것이 이해가 안가네요

앞선 강의에서 배열에서 최대를 구할때는 

max라는 변수를 하나 만들고 거기에 max = scores[0]; 이런식으로 하나 대입하여서

if (max < scores[i]) {

max = scores[i];

}

배열을 하나씩 비교하면서 크면 바꿔주고 이런식이라서

이번 선택정렬도 이런식으로 비교하면 될줄알아서

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

int small = arr[0];

for (int j = i + 1; j < length; j++) {

if(small > arr[j])

}

}

이렇게 해봤는데

아예 이상하게 나와버리네요 ㅜㅜ

C++

답변 1

1

안소

정렬을 한다는 것은 크기 순서대로 줄 세우는게 목표라는 것이니까 

이는 곧 "내 앞에 있는게 나보다 더 크다면 나와 자리를 바꿔야한다"는 의미가 됩니다. (오름차순 정렬이라면)

if (arr[i] > arr[j]) { // ? 

int temp = arr[j]; 

arr[j] = arr[i];

arr[i] = temp;

} 

이게 저 문장을 코드로 쓴 것이구요! (j는 i보다 항상 뒤죠. for문 보면 아시겠지만 i + 1 부터 시작이니까요)

최소값 최대값 갱신할 때는 순서대로 살펴보면서

"지금까지 최대값으로 알고 있었던 것보다 더 큰 값이 등장했다면 그게 새로운 최대값"이여야겠죠?

if (max < scores[i]) {

max = scores[i];

}

이게 그런 의미의 코드인 것이구요!

 

정렬 코드를 이해하기 위해선 눈으로 직접 하나하나 정렬해나가는 과정을 확인하는 것이 최고인 것 같아요.

https://www.youtube.com/watch?v=wPSz0Wm3338

https://www.youtube.com/watch?v=yXE9kFLHSOs

https://www.youtube.com/watch?v=g-PGLbMth_g

유튜브에 정렬을 시각적으로 표현한 영상 많으니 한번 참고해보시길 바래요

0

vpemflrkql0926

감사합니다~!

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

1

481

1

메모리 주소 10진수로 출력

1

672

1

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

1

515

1

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

1

549

1

메모리 주소에 관한 질분

0

687

1

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

0

558

1

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

0

448

1

Digit 뒤에 reference를 사용하는 이유

0

512

1

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

0

325

1

dat파일이...

0

540

1

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

0

651

1

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

0

456

1

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

1

392

1

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

0

565

1

마지막 예제 질문

0

305

1

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

0

382

1

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

1

416

1

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

0

313

1

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

0

448

1

3분 17초 질문

0

354

1

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

0

450

1

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

0

453

2

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

0

304

1

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

1

495

1