//以下是解题《C++程序设计题解与上机指导》chapter 6.20的总结.
#include<iostream>
using namespace std;
void sort(int **p, int n);
void main()
{ int i, n, data[10], **p, *pstr[10];
cout<<"input n:";
cin>>n;
for(i=0; i < n; i++)
{ cin>>*(data + i); //*(data + i)相当于*(&data[i]) 即data[i]
*(pstr + i) = (data + i); //相当于pstr[i] = &data[i]; 注意data前面的“&”不可省略
}
p=pstr;
sort(p, n);
cout<<"Now, the sequence is:";
for(i=0; i < n; i++)
cout<<*(*(pstr + i))<<" ";
cout<<endl;
//实现了pstr与data输出结果不一致
for(i=0; i < n; i++)
cout<<data[i]<<" ";
cout<<endl;
}
void sort(int **p, int n)
{ int i, j, *t;
for(i=0; i < n-1; i++)
for(j=i+1; j < n; j++)
//for(j=0; j < n; j++) //注意细节此处j=i+1不能改成j=0,否则上次循环的结果就会丢失
if(**(p + i) > **(p + j))
{ t = *(p + i);
*(p + i) = *(p + j);
*(p + j) = t;
}
}
指针的指针使用总结
最新推荐文章于 2022-11-04 04:32:32 发布
206

被折叠的 条评论
为什么被折叠?



