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

2019-12-22 16:00:58来源:博客园 阅读 ()

新老客户大回馈,云服务器低至5折

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

#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
如有疑问请与原作者联系

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:c++-继承的学习

下一篇:c++-多态的练习