#include<iostream>
#include<stdlib.h>
#include<string.h>
using namespace std;
void input(char *city[],int n); 
void sort(char *city[],int n); 
int main()
{ 
    int i= 0,m; 
	cout<<"输入城市个数:"<<endl;
	cin>>m;
	char **city=new char *[m];//生成了指针city,指向数组city[m],city[i]分别指向各个城市的名称
	input(city,m);     //输入m个城市的名称,以及指向首地址的指针
	sort(city,m);  //排序函数排序
    cout<<"城市按拼音排列输出如下:\n"; 
	for(i=0;i<m;i++)
    cout<<city[i]<<endl;    //用数组方式解引和指针方式效果相同,即输出*(city+i)和输出city[i]的效果相同,都是输出整个字符串
	return 0; 
} 
void input(char *city[],int n)  //input函数的形参接收city[i]数组的首地址,
{ 
	char str[20]; 
	int i; 
	cout<<"请输入"<<n<<"个城市的名字(请用拼音):\n";
    //start
    for(i=0;i<n;i++)
    {
        cin>>str;
        city[i]=(char*)malloc(sizeof(char)*(strlen(str)+1));  //动态申请数组,用city[i]指向,比如city[0]存放的是第一个城市名字
        strcpy(city[i],str);
    }
}
//start
//对city数组里存放的城市名字排序,用strcmp函数
void sort(char *city[],int n)
{ 
    char *temp;
    int i,j;
    for(i=0;i<n;i++)
    {
        for(j=1;j<n-1;j++)
        {
            if(strcmp(city[j],city[j-1])<0)
            {
                temp=city[j-1];
                city[j-1]=city[j];
                city[j]=temp;
            }
        }
    }
	//end
}
原文:https://www.cnblogs.com/cloverlp/p/12081531.html