inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

6.4 배열과 선택 정렬 selection sort

정렬코딩을 짜봤는데 정렬이 안됩니다 어디가 잘못되었는지 봐주세요 ㅠㅠ

204

jsh4059

작성한 질문수 34

0

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 ij = 0;

int a[length] = { 3,5,2,1,4 };

//swap

//int temp = int[0];

//int[0] = int[1];

//int[1] = int temp;

printArray(a, length);

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

{

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

{

if (a[i] > a[j])

ij = a[j];

    a[j] = a[i];

    a[i] = ij;

}

}

printArray(a, length);

}

이렇게 하면 정렬이 될꺼라 생각했는데 계속 안되네요 어디가 잘못된건가요?

C++

답변 1

1

안소

안녕하세요!

이렇게 자리를 바꿔치기하는 3 줄의 과정을 중괄호로 함께 묶어주셔야 합니다.  앞에 있는 것 a[i]이 뒤에 있는 것 a[j] 보다 크면 자리를 바꿔야하죠. 근데 자리를 바꾸는 과정은 저 3 줄로 이루어져야 하기 때문입니다.

질문자님 코드는 이렇게 된 것이나 마찬가지입니다. 자리를 바꿔주는 처리를 저 3줄로 해야하는데 첫번재줄만 해주시게 된거에요. 중괄호를 쳐주지 않아 첫번째줄인 ij = a[j] 만 for문 내의 statement 로 처리되었기 때문입니다. 나머지 두 줄은 a[j] > a[j] 에 해당하지 않더라도 모든 경우에 다 처리 되었기 때문에 제대로된 결과가 나오지 않았던 것이에요! 

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

1

463

1

메모리 주소 10진수로 출력

1

653

1

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

1

498

1

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

1

534

1

메모리 주소에 관한 질분

0

678

1

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

0

548

1

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

0

442

1

Digit 뒤에 reference를 사용하는 이유

0

509

1

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

0

322

1

dat파일이...

0

537

1

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

0

642

1

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

0

453

1

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

1

388

1

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

0

560

1

마지막 예제 질문

0

301

1

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

0

373

1

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

1

410

1

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

0

310

1

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

0

446

1

3분 17초 질문

0

350

1

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

0

445

1

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

0

441

2

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

0

299

1

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

1

491

1