C++关于数字逆序输出的两种思路,及字符串逆序输出

作者:GREATCOFFEE 发布时间:NOVEMBER 15, 2012 分类:编程的艺术

  最近在跟女神一起学C++(其实我是不怀好意),然后女神有个作业求助,要求输入一个数字,然后程序将数字逆序输出。这机会必须把握的啊,于是咱就毅然接下了这个任务。

  其实那个时候还不会,于是就去百度了……不得不说,别人写的码质量参差不齐啊,没一个我能看上的,于是那天晚上就通宵看书(《写给大家看的C++书》[美]Larry Ullman & Andreas Signer著/杨涛&王建桥&杨晓云等译,推荐),随手翻到第12章,发现有.substr()这个函数,于是果断采取如下思路:

1、将整型(int)用itoa()函数转化为字符串(string);

2、利用.substr()函数将字符串每次取1个单位长度,从后往前取,将这些子字符串加到新空字符上;

3、(可选)将字符串用atoi()函数重新转化为整型。

这样基本上用到了2(或者3)个函数:itoa()和.substr。这两个函数的用法如下:

itoa():itoa(IntIn, TempChar, scale);

       IntIn:需要转换的整型;

    TempChar:用于放置每一位数字的临时字符数组;

    scale:进位制,如10即10进制。

.substr():ParentStr.substr(Position, units);

ParentStr:需要取子字符串的字符串;

Position:取字符串开始的位置,如第一位为0,第二位位1;

units:取的位数,取一位即1。

具体代码如下,基本上每一行都有注释哟~

  1. #include<iostream>//输入输出流,cin、cout等函数在此头文件里;
  2. #include<string>//字符串头文件,字符串相关函数在此头文件里;
  3. #include<cstdlib>//C标准函数库。itoa()函数和system()函数都存在于这个头文件里。
  4. int main()
  5. {
  6. intNumIn;
  7. std::cout <<"请输入一个整数:\n";
  8. std::cin >>NumIn;//获取整数输入
  9. std::cin.ignore(100,'\n');//丢弃换行符。
  10. charTempChar[10];//创建临时数组用于存放字符串元素。因int的取值范围为2^32,
  11. //故10个元素足矣。
  12. std::stringNumStr;//定义字符串,用来存放数字。
  13. NumStr= itoa(NumIn,TempChar,10);//数字转字符串。并赋给NumStr。
  14. unsignedshortStrSize=NumStr.size();//获取字符串长度并赋给StrSize。
  15. unsignedshort i =1;//定义计数变量,用于下面的for循环。
  16. std::stringNumReverseStr;//定义字符串,用来存放逆序数。
  17. if(NumIn<0)//判断整型是否为负。负数如果直接转换成字符串再从后往前取子字符
  18. //串,会导致负号显示在最后,所以需要对负数进行特殊处理。
  19. {
  20. NumReverseStr+="-";
  21. for(i =0; i <=StrSize-2; i++)
  22. //从i = 0开始,到i = StrSize - 2结束,执行循环。
  23. //因为第一个元素为负号,所以只需要从后往前取到第二个(StrSize - 2)。
  24. {
  25. NumReverseStr+=NumStr.substr(StrSize-1- i,1);
  26. //取子字符串函数,从后往前取,每次取1个元素,然后加到逆序数字符串
  27. //NumReverseStr上。字符串可加,后面的字符串接到前面字符串的后面。
  28. }
  29. }
  30. else//当整型不小于0时,即可直接取。
  31. {
  32. for(i =0; i <=StrSize-1; i++)
  33. //从i = 0开始,到i = StrSize - 1结束,执行循环。
  34. //这里没有负号,因此可以将所有元素取完。
  35. {
  36. NumReverseStr+=NumStr.substr(StrSize-1- i,1);//注释见上
  37. }//循环结束
  38. }
  39. std::cout <<"您输入的数字的逆序输出是:"<<NumReverseStr<<"\n\n";
  40. system("pause");//暂停函数,防止代码执行完之后直接退出。
  41. return0;
  42. }

以上即完整代码,大家可以编译执行一下。

代码发给女神之后,没两天,女神发回来她一同学写的,说比我这简短得多……我一看,确实简短得多……而且写这码的是男的,瞬间让我……

他是用数学方法做的,代码如下解释都写在注释里面了:

  1. #include<iostream>
  2. int main()
  3. {
  4. int x,a,b;
  5. std::cout <<"请输入一个正整数:";
  6. std::cin >> x;
  7. a = x %10;//用x除以10取余数,比如123 % 10 = 3,即123除以10余3,将3赋给a
  8. //作为逆序第一位。
  9. do
  10. {
  11. b = x /10%10;
  12. //因为x、b是整数,所以b除以10之后得到的仍是整数。
  13. //以123为例,123 / 10 = 12;在C++里是这样计算的。
  14. //得到12之后,除以10取余,如12 % 10 = 2,将2赋给b。
  15. a = a *10+ b;
  16. //将开始得到的a乘以10再加上b,此时a = 3 * 10 + 2 = 32;
  17. x = x /10;
  18. //x除以10得到一整数,第一次循环即得到12,然后重新进行循环。
  19. }
  20. while(x /10!=0);
  21. std::cout<<"输入数的倒置为:"<< a << std::endl;
  22. return0;
  23. }

  他这段是用数学方法写的,看了之后我瞬间觉得我的码弱爆了……我那50行代码就被这压缩压缩不超过10行的代码给秒掉了……他这俨然是初中数学的方法,想来我从初中开始数学就不给力了……这教育我们,数学一定要学好,不然连妹子都没得泡……

好吧言归正传。我那段代码是依赖于函数的,而且对数学不好的同学来说非常好理解,又很容易写出来。

而他那段代码是用数学方法写出来的,非常简短,动动脑筋就可以省下很多功夫……

不过,由于C++在Windows下的取值范围只是从-2147483648~2147483647,顶多有10位,超出范围的时候就会显示不正确,因而也就无法用于计算;此时,用字符串的方法就有绝对的优势了。而且稍微改一下,就能用于任意字符的逆序。因此尽管代码较多,而且可能速度略慢,还是有其存在意义的。

至于任意字符串的反序,部分代码如下,有需要的同学请自己改一改吧,我实在懒了:

  1. unsignedshortStrSize=StrIn.size();//获取字符串长度(.size()函数)。
  2. stringStrReverse;
  3. unsignedshort i =0;
  4. for(i =0; i <=StrSize-1; i++)
  5. {
  6. StrReverse+=StrIn.substr(StrSize-1- i,1);
  7. }

转载 http://www.avdir.com/programming/C--shuzinixushuchu/

C++关于数字逆序输出的两种思路,及字符串逆序输出的更多相关文章

  1. php 冒泡排序的两种思路以及优化

    php冒泡排序,两种思路,时间复杂度都是O(n^2),当然最优的时间复杂度就是O(n),以下说的都是正序排列(倒序的话,把内层循环的大于号换成小于号就好了) 第一种冒泡排序 思路就是把第一个数跟所有的 ...

  2. 把JSON数据载入到页面表单的两种思路(对easyui自带方法进行改进)

    #把JSON数据载入到页面表单的两种思路(对easyui自带方法进行改进) ##背景 项目中经常需要把JSON数据填充到页面表单,一开始我使用easyui自带的form load方法,觉得效率很低,经 ...

  3. Java实现快排+小坑+partition的两种思路

    在做一道剑指Offer的题的时候,有道题涉及到快排的思路,一开始就很快根据以前的思路写出了代码,但似乎有些细节不太对劲,自己拿数据试了下果然.然后折腾了下并记录下一些小坑,还有总结下划分方法parti ...

  4. 点击页面div弹窗以外隐藏的两种思路

    在本文为大家介绍两种思路实现点击页面其它地方隐藏该div,第一种是对document的click事件绑定事件处理程序.. 第一种思路分两步 第一步:对document的click事件绑定事件处理程序, ...

  5. 使用 CUDA 进行计算优化的两种思路

    前言 本文讨论如何使用 CUDA 对代码进行并行优化,并给出不同并行思路对均值滤波的实现. 并行优化的两种思路 思路1: global 函数 在 global 函数中创建出多个块多个线程对矩阵每个元素 ...

  6. 第七篇:使用 CUDA 进行计算优化的两种思路

    前言 本文讨论如何使用 CUDA 对代码进行并行优化,并给出不同并行思路对均值滤波的实现. 并行优化的两种思路 思路1: global 函数 在 global 函数中创建出多个块多个线程对矩阵每个元素 ...

  7. 密码等级:至少包含字母、大小写数字、字符中的两种 JS实现方案

    前言 密码,如果设置的太简单,很容易就被攻破,所以很多网站将密码设置的要求设置的挺严格,一般是字母.数字.字符3选2,区分大小写.对于设置得太简单的密码,予以错误提示.或者予以密码等级(低中高)显示, ...

  8. 微软BI 之SSIS 系列 - 两种将 SQL Server 数据库数据输出成 XML 文件的方法

    开篇介绍 在 SSIS 中并没有直接提供从数据源到 XML 的转换输出,Destination 的输出对象有 Excel File, Flat File, Database 等,但是并没有直接提供 X ...

  9. [正经分析] DAG上dp两种做法的区别——拓扑序与SPFA

    在下最近刷了几道DAG图上dp的题目. 要提到的第一道是NOIP原题<最优贸易>.这是一个缩点后带点权的DAG上dp,它同时规定了起点和终点. 第二道是洛谷上的NOI导刊题目<最长路 ...

随机推荐

  1. Linux内核分析(五)----字符设备驱动实现

    原文:Linux内核分析(五)----字符设备驱动实现 Linux内核分析(五) 昨天我们对linux内核的子系统进行简单的认识,今天我们正式进入驱动的开发,我们今后的学习为了避免大家没有硬件的缺陷, ...

  2. Oracle 11g oracle客户端(32位)PL/SQL develepment的安装配置

    Oracle 11g+oracle客户端(32位)+PL/SQL develepment的安装配置 之前一直想学Oracle,可是就是安装配置Oracle一直未成功,让人很苦恼,特别是什么监听器什么的 ...

  3. Swift: 打造滑动解锁文字动画

    原文:Swift: 打造滑动解锁文字动画 最近木事,找出来玩了玩facebook的paper.到处都是那个"slide to unlock your phone"的效果啊.忽闪忽闪 ...

  4. C文件IO

    ANSI C标准差点儿被全部的操作系统支持,ANSI C标准提供了完好的I/O函数,使用这些I/O操作我们能够控制程序的输入输出.读写系统磁盘文件.本文记录了用户进程I/O缓冲介绍.文件的读写.文件定 ...

  5. Ubuntu 14.1 构造NFS

    主办IP:129.1.4.189.目标计算机IP:129.1.22.96 1.运行命令:apt-get install nfs-kernel-server ; 2.运行命令:mkdir /tftpbo ...

  6. POJ 2502 Subway (Dijkstra 最短+建设规划)

    Subway Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 6689   Accepted: 2176 Descriptio ...

  7. Socket 由浅入深系列--------- 简单实现编程(三)

    socket 由浅入深 原理(一)介绍了一些,以下也就是简单实现,并未考虑其它性能化! 使用TCP的server客户机举例 server 设置一个简单的TCPserver涉及下列步骤: 调用 sock ...

  8. APMServ—我用过的最优秀的PHP集成环境工具

    原文:APMServ-我用过的最优秀的PHP集成环境工具 经常折腾wordpress和各种cms,免不了要在本地测试一些程序,所以选择一款好的php集成环境就至关重要啦. 1. 我用过的php集成环境 ...

  9. c# WebBrowser开发参考资料

    原文:c# WebBrowser开发参考资料 c# WebBrowser开发参考资料,所有资料的采集均来自网上 话说有了WebBrowser类,终于不用自己手动封装SHDocVw的AxWebBrows ...

  10. centos7的安装

    初装centos7还是在九月份,那时候关于win7 下centos7硬盘安装的资料很少,现在就好多, 在这里备份下东西吧 首先是安装的时候,关于找从那个地方找image的问题. hda ,sda分别表 ...