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

0
9

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

<

发布回复

请输入评论!
请输入你的名字