#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;
}