题面:
字符串排序:要求编写程序,将给定字符串中的字符,按照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;
}
下面是运行结果:
文章来源:https://www.toymoban.com/news/detail-447813.html
中间可能会有小错,欢迎大家来纠错哦~ ヽ(✿゚▽゚)ノ文章来源地址https://www.toymoban.com/news/detail-447813.html
到了这里,关于从键盘输入一个字符串,将此字符串按字符的ASCII码值从小到大排序,并显示排序后的字符串。的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!