赞
踩
字符串排序:要求编写程序,将给定字符串中的字符,按照ASCII码顺序从小到大排序后输出。
输入是一个以回车结束的非空字符串。
输出排序后的结果字符串。
bfh3q487ybefg734
3344778bbeffghqy
思路:
Dwl同学一开始给我的代码是这样的
可以很明显的看到,他知道自己错在哪,但不明白为什么错了(~ ̄(OO) ̄)ブ
首先我们先来谈谈EOF的问题,EOF是end of file的缩写,表示"文字流"(stream)的结尾。 这里的"文字流",可以是档案(file),也可以是标准输入(stdin)。在C语言标准函数库(stdio.h)中被定义为一个常量,一般为值-1。C语言中,EOF常被作为文件结束或判断调用一个函数是否成功的标志。其中循环while语句经常会使用EOF判断输入是否结束,如:
- #include<stdio.h>
- int main(){
- char a;
- while(scanf("%c",&a)!=EOF){}
- return 0;
- }
这里要注意手动输入时,需要先Ctrl + z再按 Enter 键结束输入,这样系统才会结束while。
冷知识:按位取反符号~可将-1转换为0,所以直接使用如下语句也是可以达到效果哒。
while(~scanf("%c",&a)){}
回过头来我们谈谈D同学的问题,很明显,a是一个字符类型数组,而%c是以字符类型读入,于是,我们可以有以下几种解决办法:
一,利用自加运算符
while(scanf("%c",&a[flag++])!=EOF){}
二,利用指针
- char *p=a;
- while(scanf("%c",p++)!=EOF) flag++;
以自加运算符为例,我们可以得到完整代码如下:
- #include<stdio.h>
- int main(void){
- int flag=0;
- int temp;
- char a[1000];
- while(scanf("%c",&a[flag++])!=EOF){}
- for(int i=0;i<flag-1;i++){
- for(int j=0;j<flag-1;j++){
- if(a[j]>a[j+1]){
- temp=a[j];
- a[j]=a[j+1];
- a[j+1]=temp;
- }
- }
- }
- for(int i=0;i<flag;i++)
- printf("%c",a[i]);
- }
写完之后,我不禁陷入沉思,明明只要读一行字符串,为什么要用到这么复杂的判断呢,实际上,运用代码scanf("%s",a);就可以直接得到一行字符串的数据,而C语言<string.h>库函数中的strlen()函数可以直接读取字符串的长度,所以,我又写了如下代码:
- #include<stdio.h>
- #include<string.h>
- int main(void){
- int len,temp,flag=0;
- char a[1000];
- scanf("%s",a);
- len=strlen(a);
- for(int i=1;i<len;i++)
- for(int j=0;j<len-i;j++)
- if(a[j]>a[j+1]){
- temp=a[j];
- a[j]=a[j+1];
- a[j+1]=temp;
- }
- printf("%s",a);
- return 0;
- }
这时候,即使是手动输入也只需要一个回车就可以解决所有问题。不过这个代码也有局限,就是不能多行输入,而上面一个代码多行输入后会将所有字符转化到一行输出,所以我们只要整合一下,一个更完美的代码就诞生了:
- #include<stdio.h>
- #include<string.h>
- int main(void){
- int len,temp,flag=0;
- char a[1000];
- while(scanf("%s",a)!=EOF){
- len=strlen(a);
- for(int i=1;i<len;i++)
- for(int j=0;j<len-i;j++)
- if(a[j]>a[j+1]){
- temp=a[j];
- a[j]=a[j+1];
- a[j+1]=temp;
- }
- printf("%s\n",a);
- }
- return 0;
- }
下面是运行结果:
中间可能会有小错,欢迎大家来纠错哦~ ヽ(✿゚▽゚)ノ
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。