int *d_bubblesort(int a[],int n)//数组长度为n的冒泡降序排序
{
int i,j;
int temp;
for(i=0;i {
for(j=n-1;j>i;j--)
{
if(a[j]>a[j-1])
{
temp=a[j-1];
a[j-1]=a[j];
a[j]=temp;
}
}
}
return(a);
}
void main()
{
int i;
int *p;
int a[10]={6,5,4,1,2,3,9,8,7,10};
int (*fun)(int,int);
fun=d_bubblesort;
p=fun(a,10);
for(i=0;i<10;i++)
{printf("%d",p);p=p+1;}
}
这是一个经过简化的可以选择功能的程序 主函数的意思是先定义函数指针*fun 然后指向排序函数 执行fun所指向的函数(就是排序) 然后排序函数会返回排好序的数组的首地址,最后进行输出
我知道这个算法肯定有错误 但是不知道错在哪里 希望高手能指正.
int (*fun)(int,int);你这应该是指向一个返回为int,参数为(int,int)的函数,不是返回为int*的函数。
//直接把你代码拷下来看了下改了改=。=结果已经对了…至于正确的用法…嘛,其实我一直不求甚解的,附代码括弧修改处有注释括弧完:
int *d_bubblesort(int a[],int n)//数组长度为n的冒泡降序排序
{
int i,j;
int temp;
for(i=0; i<n; i++)
{
for(j=n-1; j>i; j--)
{
if(a[j]>a[j-1])
{
temp=a[j-1];
a[j-1]=a[j];
a[j]=temp;
}
}
}
return(a);
}
void main()
{
int i;
int *p;
int a[10]= {6,5,4,1,2,3,9,8,7,10};
int (*fun)(int,int);
fun=d_bubblesort;
p=fun(a,10);
for(i=0; i<10; i++)
{
printf("%d ",*p);//输出应该是指针内容啊,你输出指针想干啥……
p=p+1;
}
}