스마트 정렬 알고리즘의 일종 (확실하지만 확실하지는 않습니다.)이 있는지 궁금합니다.스왑 될 항목에 대한 정보를 반환하는 정렬 알고리즘
스마트 정렬 알고리즘이란 무엇을 의미합니까? 예를 들어 고려하자 :
이1, 2, 3, 4, 5
가 그럼 난 2, 4를 교환, 그래서 내가 가진 :
두 번째 단계로1, 4, 3, 2, 5
내가 5를 교환하고
을 나는 분류 표에서 5 개 숫자를했습니다 2 그래서 최종 결과는 다음과 같습니다 알고리즘에 대한
1, 5, 3, 2, 4
내 기대가 입력 (1, 5로 마지막 세트를 배치하는 것입니다, 3, 2, 4), 결과적으로 두 번째와 다섯 번째 항목을 교환해야하고 두 번째와 네 번째 목록을 정렬해야한다는 정보를 얻고 싶습니다.
정렬 네트워크의 사용에 대해 생각해 보았습니다. 특정 크기의 데이터에 대해 필요한 모든 비교 및 스왑 지침을 생성 한 다음 입력 데이터에 대해 수행 할 스왑을 반환 할 수 있지만 다른 방법이있을 수 있습니까?
어떻게해야합니까?
이 질문을 확인하십시오 : http://stackoverflow.com/questions/220044/which-sort-algorithm-works-best-onmost-sorted-data – jbaylina
최적의 스왑 전략을 찾는 것이 어렵다고 생각합니다. 배열을 정렬하면됩니다. – Henry
나는 당신이 찾고있는 것이 시퀀스를 정렬하는 데 필요한 스왑 연산의 최소 수라고 생각한다. 웹 검색에 "최소 스왑 연산 정렬"을 던지면 시작할 때까지 충분한 결과가 나타납니다. –