码迷,mamicode.com
首页 > 编程语言 > 详细

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

时间:2019-12-23 00:25:27      阅读:111      评论:0      收藏:0      [点我收藏+]

标签:申请   输出   字符   字符串   strcmp   char s   strcmp函数   函数   使用   

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

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

标签:申请   输出   字符   字符串   strcmp   char s   strcmp函数   函数   使用   

原文地址:https://www.cnblogs.com/cloverlp/p/12081531.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!