欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

使用动态数组,按照城市名字拼音排序

程序员文章站 2024-02-05 15:42:22
#include#include#includeusing namespace std;void input(char *city[],int n); void sort(char *city[],int n); int main(){ i ......

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