c语言字符排序函数 c语言字符串中字符排序

C语言字符串快速排序函数

#include stdio.h

创新互联坚持“要么做到,要么别承诺”的工作理念,服务领域包括:成都做网站、网站制作、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的临夏州网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!

#includestdlib.h

#includestring.h

int comp(char *a,char *b)

{

while(*a==*b*a*b){a++;b++;}

return (int)*a-(int)*b;

}

int main(void)

{

char s[1000][20];

int i,n;

scanf("%d\n",n);

for(i=0;in;i++)

gets(s[i]);

qsort(s,n,sizeof(s[0]),comp);

printf("\n");

for(i=0;in;i++)

puts(s[i]);

system("pause");

return 0;

}

C语言如何用自定义函数进行字符排序?

void fun(char a[])

{ int k=0,i,j;

char t;

while(a[k])

k++;//计算字符串长度

for(i=0;ik;i++)//冒泡排序

for(j=0;jk-1-i;j++)

if(a[j]a[j+1])

{t=a[j];

a[j]=a[j+1];

a[j+1]=t;}

}

C语言字符串排序

#include stdio.h

#include string.h

#include malloc.h

#define MAX 10

void stsrt(char *str[],int num);

void ASC(char *str[],int num);

void length_add(char *str[],int num);

void word_length(char *str[],int num);

int main(void) {

char *s[MAX],t[80];

int i = 0,n;

printf("输入%d个字符串 :\n",MAX);

for(i = 0; i MAX; ++i) {

if(gets(t) t[0] != '\0') {

s[i] = (char *)malloc(80 * sizeof(char));

strcpy(s[i],t);

}

else break;

}

while(i MAX gets(s[i]) s[i][0] != '\0') i++;

puts("选择:");

puts("1.输出初始字符串列表");

puts("2.按ASCⅡ码顺序输出字符串");

puts("3.按长度递增顺序输出字符串");

puts("4.按字符串第一个单词长度输出字符串");

puts("5.结束");

while(scanf("%d",n) != 5) {

switch(n) {

case 1:stsrt(s,i);break;

case 2:ASC(s,i);break;

case 3:length_add(s,i);break;

case 4:word_length(s,i);break;

case 5:return 0;

default:puts("输入错误!");

}

}

return 0;

}

void stsrt(char *str[],int num) { //1.输出初始字符串列表

int n;

for(n = 0;n num;n++) puts(str[num]);

}

void ASC(char *str[],int num) {//2.按ASCⅡ码顺序输出字符串

int top,seek;

char *temp;

for(top = 0;top num - 1;top++) {

for(seek = top + 1;seek num;seek++)

if(strcmp(str[top],str[seek]) 0) {

temp = str[top];

str[top] = str[seek];

str[seek] = temp;

}

}

for(int n = 0;n num;n++) puts(str[n]);

}

void length_add(char *str[],int num) { //3.按长度递增顺序输出字符串

char *temp;

int top,seek;

for(top = 0;top num - 1;top++) {

for(seek = top + 1;seek num;seek++)

if(strlen(str[top]) strlen(str[seek])) {

temp = str[top];

str[top] = str[seek];

str[seek] = temp;

}

}

for(int n = 0;n num;n++) puts(str[n]);

}

void word_length(char *str[],int num) {//4.按字符串第一个单词长度输出字符串

char *temp;

int top,seek,n,j,len[MAX];

for(n = 0; n num; ++n) {

len[n] = 0;

j = 0;

while((str[n][j] != ' ') str[n][j]) {

++len[n];

++j;

}

}

for(top = 0;top num - 1;top++) {

for(seek = top + 1; seek num;seek++) {

if(len[top] len[seek]) {

temp = str[top];

str[top] = str[seek];

str[seek] = temp;

}

}

}

for(n = 0;n num;n++) puts(str[n]);

}

C语言:将输入的字符串按首字母顺序排列。

#includestdio.h

#includestring.h

void sort(char *a[]);

void print(char *a[]);

int main()

{

char *a[] ={"ceo","define","basic","abc","empty"};

printf("原来的序列是:\n");

print(a);

sort(a);

printf("\n排序后的序列是:\n");

print(a);

printf("\n");

return 0;

}

void sort(char *a[])

{

int i,j;

char *temp;

for(i=0;i4;i++)//注意是i4

{

for(j=0;j4;j++)//注意是j4,因为下面要+1和后面的那个字符串比较

{

if(strcmp(a[j],a[j+1])0)//字符串比较:0表示前面的字符串比后面的大则交换

{

temp=a[j];

a[j]=a[j+1];

a[j+1]=temp;

}

}

}

}

void print(char *a[])

{

int i;

for(i=0;i5;i++)

{

printf("%s ",a[i]);

}

}

运行效果:

扩展资料:

return 0的用法:

return的作用是结束正在运行的函数,并返回函数值。return后面可以跟一个常量,变量,或是表达式。

函数的定义一般是这样的,例如:

inta(inti)//第一个int是函数的返回值的类型,也就是return后面跟的值的类型,a是函数的名称,括号里的是传递给函数的参数,int是参数的类型,i是参数的名字

...//省略函数体内容

returnb;//b必须与函数头的返回值一致(此处为int型)

简单函数举例:

intaddOne(intb)

returnb+1;

该函数的作用是取得一个数,将这个数加上1,再将结果返回

调用时这样:

intresult=addOne(2);//此时result的值为3

函数括号里的参数也可以为变量或能算出值的表达式

以上就是一个基本的函数,一般的函数都有返回值,也就是return后面跟的值,返回值可以为各种数据类型,如:int,float,double,char,a[](数组),*a(指针),结构或类(c++)

但不是所有函数都有返回值,如果某个函数无返回值,那么返回值的位置则为“void”关键字,此时函数体中无返回值,即无return的值。但是函数中也可出现return,即一个空的return句子,其作用是使函数立即结束,如voidprint()//括号中为空表示无传递参数、

printf("a");

printf("b");

return;//函数执行到此处结束

printf("c");

}//该函数只执行到return语句处,即屏幕上输出的为"ab"


当前名称:c语言字符排序函数 c语言字符串中字符排序
转载来源:http://azwzsj.com/article/dddighd.html