刘伊皓 2022-10-19 18:40 采纳率: 100%
浏览 35
已结题

为什么我写的希尔排序不运行呢?c语言

#include <stdio.h>
void swap(int arr[],int a,int b)
{int temp=arr[a];
arr[a]=arr[b];
arr[b]=temp;
}
void shellsort(int arr[],int n)
{ int i,j,temp,a;
for(a=n/2;a>0;a=a/2)
{ for(i=a;i<n;i++)
{
for(j=i-a;j-=a;j>=0)
{
if(arr[j+a]<arr[j])
{ swap (arr,j+a,j);}
}
}
}
}
#define n 8
int main( )
{ int i;
int arr[n] = {6,5,3,1,8,7,2,4};
for(i=0;i<8;i++)
printf("%d",arr[i]); //输出排序前的所有数组元素
printf("\n");
shellsort(arr,n); //直接调用前面定义的希尔排序函数
for(i=0;i<n;i++)
printf("%d", arr[i]); //输出排序后的所有数组元素

}

  • 写回答

2条回答 默认 最新

  • .LAL. C/C++领域新星创作者 2022-10-19 19:22
    关注
    
    #include <iostream>
    #include <vector>
    
    using namespace std;
    
    vector<int> ShellSort(vector<int> list){
        vector<int> result = list;
        int n = result.size();
        for (int gap = n >> 1; gap > 0; gap >>= 1){
            for (int i = gap; i < n; i++){
                int temp = result[i];
                int j = i - gap;
                while (j >= 0 && result[j] > temp){
                    result[j + gap] = result[j];
                    j -= gap;
                }
                result[j + gap] = temp;
            }
            for (int i = 0; i < result.size(); i++){
                cout << result[i] << " ";
            }
            cout << endl;
        }
        return result;
    }
    
    void main(){
        int arr[] = { 6, 4, 8, 9, 2, 3, 1 };
        vector<int> test(arr, arr + sizeof(arr) / sizeof(arr[0]));
        cout << "排序前" << endl;
        for (int i = 0; i < test.size(); i++){
            cout << test[i] << " ";
        }
        cout << endl;
        vector<int> result;
        result = ShellSort(test);
        cout << "排序后" << endl;
        for (int i = 0; i < result.size(); i++){
            cout << result[i] << " ";
        }
        cout << endl;
        system("pause");
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 4月14日
  • 已采纳回答 4月6日
  • 创建了问题 10月19日

悬赏问题

  • ¥15 linux驱动,linux应用,多线程
  • ¥20 我要一个分身加定位两个功能的安卓app
  • ¥15 基于FOC驱动器,如何实现卡丁车下坡无阻力的遛坡的效果
  • ¥15 IAR程序莫名变量多重定义
  • ¥15 (标签-UDP|关键词-client)
  • ¥15 关于库卡officelite无法与虚拟机通讯的问题
  • ¥15 目标检测项目无法读取视频
  • ¥15 GEO datasets中基因芯片数据仅仅提供了normalized signal如何进行差异分析
  • ¥100 求采集电商背景音乐的方法
  • ¥15 数学建模竞赛求指导帮助