问题:
题目描述
用指向指针的指针的方法对5个字符串排序并输出。要求将排序单独写成一个函数。字符串和n在主函数中输入。最后在主函数中输出。
输入
n和n个字符串
输出
排序后的字符串
样例输入
5
12345
123
abce
abcde
abcd
样例输出
123
12345
abcd
abcde
abce
提示
/* C代码 */
int main()
{
void sort(char **,int );
int i,n;
char **p,*pstr[20],str[20][80];
scanf("%d",&n);
for (i=0; i<n; i++)
pstr[i]=str[i];
for (i=0; i<n; i++)
scanf("%s",pstr[i]);
p=pstr;
sort(p,n);
for (i=0; i<n; i++)
printf("%s\n",pstr[i]);
return 0;
}
/* C++代码 */
int main()
{
void sort(char **,int );
int i,n;
char **p,*pstr[20],str[20][80];
cin>>n;
for (i=0; i<n; i++)
pstr[i]=str[i];
for (i=0; i<n; i++)
cin>>pstr[i];
p=pstr;
sort(p,n);
for (i=0; i<n; i++)
cout<<pstr[i]<<endl;
return 0;
}
#include<stdio.h>
#include<string.h>
int sort(char **p,int n)
{
int i,j;
char t[80];
for(i=0;i<n-1;i++)
{
for(j=i+1;j<n;j++)
{
if(strcmp(p[i],p[j])>0)
{
strcpy(t,p[i]);
strcpy(p[i],p[j]);
strcpy(p[j],t);
}
}
}
return 0;
}
int main()
{
void sort(char **,int );
int i,n;
char **p,*pstr[20],str[20][80];
scanf("%d",&n);
for (i=0; i<n; i++)
pstr[i]=str[i];
for (i=0; i<n; i++)
scanf("%s",pstr[i]);
p=pstr;
sort(p,n);
for (i=0; i<n; i++)
printf("%s\n",pstr[i]);
return 0;
}
总结:
<string.h>包含的函数中,strcmp用来比较,大于零就是前面的大。strcpy用来复制函数,后一个复制到前一个上面。