12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- #include <iostream>
- using namespace std;
- void ShellSort(int A[], int n) {
- int dk, i, j;
- for (dk = n / 2; dk >= 1; dk /= 2) {
- for (i = dk ; i < n; i++) {
- if (A[i] < A[i - dk]) {
- A[0] = A[i];
- for (j = i - dk; j > 0 && A[0] < A[j]; j -= dk) {
- A[j + dk] = A[j];
- }
- A[j + dk] = A[0];
- }
- }
- }
- }
- void ShellSortBySelf(int A[], int n) {
- int dk, i, j;
- int temp;
- for (dk = n / 2; dk >= 1; dk /= 2) {
- for (i = dk; i < n; i++) {
- if (A[i] < A[i - dk]) {
- temp = A[i];
- for (j = i-dk; j >= 0 && A[j]>temp; j -= dk) {
- A[j + dk] = A[j];
- }
- A[j + dk] = temp;
- }
- }
- }
- }
- int main(){
- int A1[] = {6, 1, 5, 2, 1, 9, 10, 24, 7, 0};
- ShellSort(A1, 10);
-
-
- for (int i = 0; i < 10; i++) {
- cout << A1[i] << " ";
- }
- cout << endl;
-
- int A2[] = {6, 1, 5, 2, 1, 9, 10, 24, 7, 0};
- ShellSortBySelf(A2, 10);
-
-
- for (int i = 0; i < 10; i++) {
- cout << A2[i] << " ";
- }
- cout << endl;
- return 0;
- }
|