C语言——字符串数组排序

版权声明:未经允许,不得转载 https://blog.csdn.net/frozennet/article/details/88630036

题目:利用指针数组对形参ss所指字符串数组中的字符串按由长到短的顺序排序,并输出排序结果。ss所指字符串数组中有N个字符串,且串小于M。

代码:

#include<stdio.h>
#include<string.h>

#define N 5
#define M 8

void fun(char (*ss)[M])
{
	char *ps[N],*tp;
	int i,j,k;
	
	for(i=0;i<N;i++)
		ps[i]=ss[i];
	for(i=0;i<N-1;i++)
	{
		k=i;
		for(j=i+1;j<N;j++)
		if(strlen(ps[k])<strlen(ps[j]))
			k=j;
		
		tp=ps[i];
		ps[i]=ps[k];
		ps[k]=tp;
	}
	printf("\nThe string after sorting by length: \n\n");
	for(i=0;i<N;i++)	puts(ps[i]);
 } 
 
 int main()
 {
 	char ch[N][M]={"red","green","blue","yellow","black"};
 	int i;
 	printf("\nThe original string\n\n");
 	for(i=0;i<N;i++)
 		puts(ch[i]);
 	printf("\n");
 	fun(ch);
 }

运行结果:

猜你喜欢

转载自blog.csdn.net/frozennet/article/details/88630036