inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

6.4 배열과 선택 정렬 selection sort

정렬을 했는데 방법이 특이합니다.

해결된 질문

228

재밌는코딩

작성한 질문수 2

0

이렇게 코드를 작성했는데 교수님께서 작성하신거랑 비슷하면서

결과가 많이 다름니다... 어떤 점이 틀린건가요??

#include <iostream>

using namespace std;

void printArray(int* array, int length)
{
	for (int i = 0; i < length; i++)
		cout << array[i] << " ";
	cout << endl;
}

int main()
{
	const int length = 5;
	int array[length] = { 3,5,2,1,4 };

	printArray(array, length);

	for (int i = 0; i < length; i++)
	{
		for (int j = 0; j < length-1; j++)
		{
			if (array[i] < array[j])
			{
				int k = array[i];
				array[i] = array[j];
				array[j] = k;
			}
			
		}
		printArray(array, length);
	}
	
	return 0;
}

C++

답변 1

3

안소

안녕하세요!

강의에선 '선택 정렬' 방식으로 정렬 코드를 쓰셨습니다.

첫번째 for문은 0부터 length - 1 전까지,

두번째 for문은 첫번재 for문 인덱스 + 1 부터 length 전까지.

이 범위가 선택정렬의 핵심입니다. 

파일:Selection-Sort-Animation.gif

출처 : 선택정렬 위키 백과

선택 정렬은 이렇게 앞에서부터 범위를 좁혀나가면서 오름차순 정렬을 확정해나가는 방식인데요,

질문자님 코드는 그냥 반복문 전체 (for i = 0, for j = 0)를 다 돌며 스왑하고 계십니다..! 선택 정렬 방식이 아니에요. 

저렇게하면 이미 스왑 됐던것도 다시 스왑해서 제자리로 돌려지는 과정이 많이 생길 것 같습니다. (즉, 정렬이 제대로 되지 못함)

정렬은 선택정렬말고도 알고리즘이 여러개가 있으니, 버블정렬 삽입정렬 퀵정렬 등등 다른 정렬 알고리즘 코드들도 참고해보시면서 정렬 원리를 참고해보시길 권장합니다.

 

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

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