用指向指针的指针方法对n个整数排序输出。要求将排序单独写成一个函数,n和各整数在主函数中输入,最后在主函数中输出。
```c
#include<stdlib.h>
#include <stdio.h>
void sort_numbers(int **,int );
int main()
{
int i,n,data[20],**p,*q[20];
scanf("%d",&n);
for(i=0;i<n;i++)
q[i]=&data[i];
for(i=0;i<n;i++)
scanf("%d",q[i]);
p=q;
sort_numbers(p,n);
for(i=0;i<n;i++)
printf("%d ",*q[i]);
system("pause");
return 0;
}
void sort_numbers(int **p,int n)
{
int i,j,temp;
for(i=0;i<n-1;i++)
for(j=0;j<n-1-i;j++)
{
if(*(*(p+j))>*(*(p+j+1)))// if(*p[j]>*p[j+1])
{
temp=*p[j];
*p[j]=*p[j+1];
*p[j+1]=temp;
}
}
}
关于本题,给我最大的收获的就是二级指针,之前对于二级指针了解得不够透彻,通过这道题,还有网上的一些资料,让我对于二级指针有了进一步的了解。
**int *p表示的是一级指针,表示p所指向的地址里面存放的是一个int类型的值
int p表示的是二级指针,表示p所指向的地址里面存放的是一个指向int类型的指针。
指针数组的数组名传递参数对应为指针的指针即二级指针,二维数组的数组名传递参数对应为数组指针即指向一维数组的指针
一级指针通过形参,可以修改实参中指针所指向的地址中的值。修改不了实参中指针所指向的地址。需要借助二级指针才可以.
具体更为详细的解释可以看这个链接:https://blog.csdn.net/qq_43160216/article/details/82529938