c语言 对字符串按长度大小排序

#include<stdio.h>
#include<string.h>
#include<math.h>
#include<stdlib.h>
#define SIZE 5

int main(){
	/*
	
	对给定字符串按长度大小升序排序。
	*/
 
	char * str[SIZE];
	int i,j;
	char * ch;
 
 
	for(i = 0; i < SIZE; i++){
 
		/*
		str数组里的每个指针仅声明没有指向具体的内存空间,
		指向任意内存,所以有可能指向已有内容的内存,而这是非常危险的
		所以,为每个指针开辟10个char长度空间,并让指针指向该空间
		*/
		str[i] = (char *)malloc(sizeof(char)*10);

		scanf("%s",str[i]);//读取一行,等价gets(str[i])
		
	
	
	}
 
	
	//冒泡排序法
	for(i = 0; i < SIZE; i++)
	{
		for(j = 0; j < SIZE-i-1; j++)
		{
			//如果后面的比前面的长就交换指针
			if(strlen(str[j]) > strlen(str[j+1]))
			{
				ch =  str[j];
				str[j] = str[j+1];
				str[j+1] = ch;
 
			
			}	
		}	
	
	}
 
	for(i = 0;i<SIZE; i++)
		printf("%s======",str[i]);
 
 
return 0;
}

 

    原文作者:鹰立如睡
    原文地址: https://blog.csdn.net/LVGAOYANH/article/details/104021932
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞