패리티 정렬 알고리즘 및 자바 그룹에서의 실현에 대한 간단한 설명
예를 들면,
대기열 그룹
[6 2 4 1 5 9]
첫 번째 비교 홀수열, 홀수열과 이웃 짝수열, 예를 들어 6과 2비, 4와 1비, 5와 9비
[6 2 4 1 5 9]
교환 후
[2 6 1 4 5 9]
두 번째 비교 짝수열, 즉 6과 1비, 5와 5비
[2 6 1 4 5 9]
교환 후
[2 1 6 4 5 9]
세 번째는 또 홀수열인데, 선택한 것은 2, 6, 5로 각각 그들의 이웃열과 비교하였다
[2 1 6 4 5 9]
교환 후
[1 2 4 6 5 9]
제4회 짝수열
[1 2 4 6 5 9]
교환
[1 2 4 5 6 9]
Java 구현:
static void oddEvensort(int[] ary) {
//
boolean flag = true;
while (flag) {
boolean odd = false, even = false;
for (int i = 0; i < ary.length - 1; i+=2) {
if (ary[i] > ary[i + 1]) {
ary[i] = ary[i + 1] + 0 * (ary[i + 1] = ary[i]);
odd = true;
}
}
for (int i = 1; i < ary.length - 1; i+=2) {
if (ary[i] > ary[i + 1]) {
ary[i] = ary[i + 1] + 0 * (ary[i + 1] = ary[i]);
even = true;
}
}
flag = odd || even; // false, ,
}
}
위의 flag =odd | even;하나는true로 교환되고 있음을 나타낸다. 그러면 마지막으로false일 때만 flag는false이다.flag=odd&&even으로 바꾸기;하나는false이고, 더 이상 전체적인 순환이 없다.거품 정렬과 마찬가지로 마지막 내층 순환을 줄일 수 있다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
엑셀 VBA에서 동적 계획법으로 DNA 서열의 정렬 만들기 Needleman-Wunsch 알고리즘 구현이 기사는 DNA 서열의 정렬을 반환하는 엑셀 함수에 대한 기사입니다. 그렇다면 다음과 같은 정렬을 반환하는 함수입니다. 두 개의 행렬을 준비합니다. 정렬하고 싶은 2개의 DNA 서열의 길이를 m과 n으로 하면, 세...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.