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

#include
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
{
for(j=i-a;j-=a;j>=0)
{
if(arr[j+a]
{ 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
printf("%d", arr[i]); //输出排序后的所有数组元素

}


#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");
}


#include<stdio.h>//头文件
int main()//主函数
{
  void shsort(int s[],int n); //函数声明
  int array[11],i;//定义数组和整型变量
  printf("请输入10个数:\n");//提示语句
  for(i=1;i<=10;i++)
  {
    scanf("%d",&array[i]); //键盘输入10个数
  }
  printf("初始顺序:\n");//提示语句
  for(i=1;i<11;i++)
  {
    printf("%5d",array[i]);//输出键盘输入的10个数
  }
  shsort(array,10);//调用排序函数
  printf("\n排序后顺序:\n");//提示语句
  for(i=1;i<11;i++)
  {
    printf("%5d",array[i]);//输出排序后的10个数
  }
  printf("\n"); //换行
  return 0;//函数返回值为0
}
void shsort(int s[],int n)
{
  int i,j,d;
  d=n/2;
  while(d>=1) //确定固定增量值
  {
    for(i=d+1;i<=n;i++) //数组下标从d+1开始进行直接插入排序
    {
      s[0]=s[i]; //设置监视哨
      j=i-d; //确定要比较元素的最右边位置
      while((j>0)&&(s[0]<s[j]))
      {
        s[j+d]=s[j]; //数据右移
        j=j-d; //向左移d个位置
      }
      s[j+d]=s[0]; //在确定的位置插入s[i]
    }
    d=d/2; //增量变为原来的一半
  }
}