当前位置:   article > 正文

从键盘输入一个字符串,将此字符串按字符的ASCII码值从小到大排序,并显示排序后的字符串。_请按asc增序,将给定的字符串排序显示,如"zero","one","two","three","f

请按asc增序,将给定的字符串排序显示,如"zero","one","two","three","four", , "f

题面:

字符串排序:要求编写程序,将给定字符串中的字符,按照ASCII码顺序从小到大排序后输出。

输入格式:

输入是一个以回车结束的非空字符串。

输出格式:

输出排序后的结果字符串。

输入样例:

bfh3q487ybefg734

输出样例:

3344778bbeffghqy

思路:

Dwl同学一开始给我的代码是这样的

 可以很明显的看到,他知道自己错在哪,但不明白为什么错了(~ ̄(OO) ̄)ブ

首先我们先来谈谈EOF的问题,EOF是end of file的缩写,表示"文字流"(stream)的结尾。 这里的"文字流",可以是档案(file),也可以是标准输入(stdin)。在C语言标准函数库(stdio.h)中被定义为一个常量,一般为值-1。C语言中,EOF常被作为文件结束或判断调用一个函数是否成功的标志。其中循环while语句经常会使用EOF判断输入是否结束,如:

  1. #include<stdio.h>
  2. int main(){
  3.     char a;
  4. while(scanf("%c",&a)!=EOF){}
  5.     return 0;
  6. }

这里要注意手动输入时,需要先Ctrl + z再按 Enter 键结束输入,这样系统才会结束while。

冷知识:按位取反符号~可将-1转换为0,所以直接使用如下语句也是可以达到效果哒。

while(~scanf("%c",&a)){}

回过头来我们谈谈D同学的问题,很明显,a是一个字符类型数组,而%c是以字符类型读入,于是,我们可以有以下几种解决办法:

一,利用自加运算符

while(scanf("%c",&a[flag++])!=EOF){}

二,利用指针

  1. char *p=a;
  2. while(scanf("%c",p++)!=EOF) flag++;

以自加运算符为例,我们可以得到完整代码如下:

  1. #include<stdio.h>
  2. int main(void){
  3. int flag=0;
  4. int temp;
  5. char a[1000];
  6. while(scanf("%c",&a[flag++])!=EOF){}
  7. for(int i=0;i<flag-1;i++){
  8. for(int j=0;j<flag-1;j++){
  9. if(a[j]>a[j+1]){
  10. temp=a[j];
  11. a[j]=a[j+1];
  12. a[j+1]=temp;
  13. }
  14. }
  15. }
  16. for(int i=0;i<flag;i++)
  17. printf("%c",a[i]);
  18. }

写完之后,我不禁陷入沉思,明明只要读一行字符串,为什么要用到这么复杂的判断呢,实际上,运用代码scanf("%s",a);就可以直接得到一行字符串的数据,而C语言<string.h>库函数中的strlen()函数可以直接读取字符串的长度,所以,我又写了如下代码:

  1. #include<stdio.h>
  2. #include<string.h>
  3. int main(void){
  4. int len,temp,flag=0;
  5. char a[1000];
  6. scanf("%s",a);
  7. len=strlen(a);
  8. for(int i=1;i<len;i++)
  9. for(int j=0;j<len-i;j++)
  10. if(a[j]>a[j+1]){
  11. temp=a[j];
  12. a[j]=a[j+1];
  13. a[j+1]=temp;
  14. }
  15. printf("%s",a);
  16. return 0;
  17. }

这时候,即使是手动输入也只需要一个回车就可以解决所有问题。不过这个代码也有局限,就是不能多行输入,而上面一个代码多行输入后会将所有字符转化到一行输出,所以我们只要整合一下,一个更完美的代码就诞生了:

  1. #include<stdio.h>
  2. #include<string.h>
  3. int main(void){
  4. int len,temp,flag=0;
  5. char a[1000];
  6. while(scanf("%s",a)!=EOF){
  7. len=strlen(a);
  8. for(int i=1;i<len;i++)
  9. for(int j=0;j<len-i;j++)
  10. if(a[j]>a[j+1]){
  11. temp=a[j];
  12. a[j]=a[j+1];
  13. a[j+1]=temp;
  14. }
  15. printf("%s\n",a);
  16. }
  17. return 0;
  18. }

下面是运行结果:

 中间可能会有小错,欢迎大家来纠错哦~   ヽ(✿゚▽゚)ノ

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/650504
推荐阅读
相关标签
  

闽ICP备14008679号