赞
踩
//用指针数组处理
#include<stdio.h>
#include<string.h>
int main()
{
void sort(char *[]);
int i;
char str[10][6], *p[10];
printf("please input 10 string:/n");
for(i=0;i<10;i++)//首先将10个str的首地址赋值给10个p[i];
p[i]=str[i];//将第i个字符串的首地址赋予指针数组p的第i个元素;
for(i=0;i<10;i++)
scanf("%s",p[i]);//scanf输入到&p[i]
sort(p);
printf("the output 10 string:/n");
for(i=0;i<10;i++)
printf("%s/n",p[i]);//输出到p[i];
}
void sort(char *s[])
{
char *temp;
int i,j;
for(i=0;i<9;i++)
for(j=0;j<9-i;j++)
if(strcmp(*(s+j),*(s+j+1))>0)
{
temp=*(s+j);//*(s+j)指向数组指针,我想应该是字符串的首地址;所以可以直接赋值给temp指针;
*(s+j)=*(s+j+1);
*(s+j+1)=temp;
}
}
//字符型二维数组
#include<stdio.h>
#include<string.h>
int main()
{
void sort( char s[][6]);
char str[10][6];
int i;
printf("please input string:/n");
for(i=0;i<10;i++)
scanf("%s",&str[i]);//str是指向由6个元素组成的一维数组的指针
sort(str);//str是指向由6个元素组成的一维数组的指针
printf("please output string:/n");
for(i=0;i<10;i++)
{
printf("%s",str[i]);//str是指向由6个元素组成的一维数组的指针
printf("/n");
}
return 0;
}
void sort(char s[10][6])//形参s是指向由6个元素组成的一维数组的指针
{
char *p,temp[10];
int i,j;
p=temp;
for(i=0;i<10;i++)
for(j=0;j<10-i;j++)
if(strcmp(s[j],s[j+1])>0)//格式错误不是strcmp(s[j]>s[j+1]);比较之后
{
strcpy(p,s[j]);
strcpy(s[j],s[j+1]);
strcpy(s[j+1],p);
}
}
用指向一维数组的指针做函数参数
#include<stdio.h>
#include<string.h>
int main()
{
void sort(char (*s)[6]);//一维数组的指针做函数参数
int i;
char str[10][6];
char (*p)[6];//定义一维数组的指针做函数参数
printf("please input string:/n");
for(i=0;i<10;i++)
scanf("%s",&str[i]);
p=str;//将str一维数组指针,赋值给p;
sort(p);
printf("the output sequence :/n");
for(i=0;i<10;i++)
printf("%s/n",str[i]);
return 0;
}
void sort(char (*s)[6])//s指向一维数组的指针做函数参数;
{
int i,j;
char temp[6], *t;
t=temp;
for(i=0;i<9;i++)//i应该小于9;如果小于10,那么就比较了9+1次;按照冒泡法则,
for(j=0;j<9-i;j++)//第一次比较需要9次就是i=0到i=8共九次;第二次需要比较8次;依次类推;
if(strcmp(s[j],s[j+1])>0)
{
strcpy(t,s[j]);
strcpy(s[j],s[j+1]);
strcpy(s[j+1],t);
}
}
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。