草庐IT

(C++)读取一个输入的int型十进制数字的位数,并正序输出每个位上的值(不同数位的值用1个空格字符间隔)

美人她爹 2023-03-28 原文
  1 /*
  2     程序功能:读取一个输入的int型十进制数字的位数,并正序输出每个位上的值(不同数位的值用1个空格字符间隔)。
  3     例如:当输入985这个数字时,显示如下信息:
  4          985是一个3位数字!
  5          该数字从左至右的位置上的数字依次为:9 8 5
  6     作者:美人她爹,微信:fatherofBeauty
  7     时间:2022年4月20日10:39:27
  8 */
  9 #include <iostream>
 10 #include <cmath>
 11 /*自定义关键字,标记函数参数是一个输入值*/
 12 #define IN 
 13 using namespace std;
 14 /*读取数字位数的函数*/
 15 int ReadDigitsOfNumber(IN const int number,IN const int decimalSytem);
 16 /*显示数字每个位上数字的函数*/
 17 int DisplayNumberByDigits(IN const int number,IN const int digits,IN const int deciamlSystem);
 18 int main()
 19 {
 20     int number;
 21     int digits;
 22     int decimalSystem = 10;
 23 
 24     cout<<"请输入一个十进制的数字:";
 25     cin>>number;
 26     /*调用函数ReadDigitsOfNumber(),并将函数返回值赋值给变量digits*/
 27     digits = ReadDigitsOfNumber(number,decimalSystem);
 28     /*输出输入的十进制数字的digits*/
 29     cout<<number<<"是一个"<<digits<<"位数字!"<<endl;
 30     /*调用函数DisplayNumberByDigits()*/
 31     DisplayNumberByDigits(number,digits,decimalSystem);
 32     system("pause");
 33     return 0;    
 34 }
 35 
 36 /*
 37     ReadDigitsOfNumber()函数算法原理:
 38     利用C++整型数据不保留小数位的特点,
 39     对输入数据按照进制(此程序是10)做除法去截位,
 40     即算术运算符/,具有截位功能。
 41     举例:int number = 985;
 42          number = number/10;
 43     从数学角度看,number值,应该是98.5。
 44     但是,因为number是整型数据,不保留小数位,此时,number = 98
 45     number由最初的赋值985变为98,即实现了截位。
 46 
 47     每截除1位,用一个初始值为零的变量digitsCount作为计数器,计数1次。
 48     当最后一位截完,输入数据就变为零(作为循环终止条件)
 49     此时,digitsCount保存的数据,就是输入数字的位数。
 50 */
 51 int ReadDigitsOfNumber(IN const int number,IN const int decimalSystem)
 52 {
 53     int conditionFlag;
 54     int digitsCount = 0;//将计数器初始化为零
 55     int computeDigitsWorkingNumber = number;
 56     
 57     /*do-while循环实现*/
 58     
 59     do
 60     {
 61         computeDigitsWorkingNumber = computeDigitsWorkingNumber/decimalSystem;
 62         conditionFlag = computeDigitsWorkingNumber;
 63         digitsCount = digitsCount + 1;
 64     }while(conditionFlag != 0);
 65     
 66 
 67     /*for循环实现*/
 68     /*
 69     if(computeDigitsWorkingNumber == 0) 
 70     {
 71         digitsCount = 1;
 72     }
 73     else
 74     {
 75         for(conditionFlag = computeDigitsWorkingNumber ;conditionFlag != 0;conditionFlag = conditionFlag/decimalSystem)
 76         {
 77             digitsCount = digitsCount + 1;
 78         }    
 79     }
 80     */
 81 
 82     /*用while循环实现*/
 83     /*
 84     if(computeDigitsWorkingNumber == 0) 
 85     {
 86         digitsCount = 1;
 87     }
 88     else 
 89     {
 90         
 91         //conditionFlag = computeDigitsWorkingNumber;
 92         //while(conditionFlag != 0)
 93         //{
 94         //    conditionFlag = conditionFlag/decimalSystem;
 95         //    digitsCount = digitsCount + 1;
 96         //}
 97         
 98         while(computeDigitsWorkingNumber != 0)
 99         {
100             computeDigitsWorkingNumber = computeDigitsWorkingNumber/decimalSystem;
101             digitsCount = digitsCount + 1;
102         }
103     }
104     */
105     return digitsCount;
106 }
107 /*
108     DisplayNumberByDigits()函数算法原理:
109     对于一个输入的数字,比如985,将9、8、5三个值输出。
110     用C++实现,有两种方法。
111     方法1:
112     思路:(高位捕获,依次从高位截位,迭代)
113     从十进制高位开始用整除(/)捕获数位上的值;
114     然后从高位开始进行取余(%)逐位截除;
115     如此循环迭代,直到输入数字为零,循环终止。
116     方法2:
117     思路:(低位捕获,依次从低位截位,迭代)
118     从十进制低位开始取余(%)捕获数位上的值;
119     然后从低位开始进行整除(/)逐位截除,
120     如此循环迭代,直到输入数字为零,循环终止。
121     正序输出的话,该方法需要用数组;
122 */
123 
124 /*方法1-C++实现代码*/
125 int DisplayNumberByDigits(IN const int number,IN const int digits,IN const int decimalSystem)
126 {
127     cout<<"该数字从左至右位置上的数字依次为:";
128     /*用for循环实现*/
129     
130     int displayWorkingNumber = number;
131     int displayWorkingDigits = digits;
132     
133     for(int displayWorkingCount = 0;displayWorkingCount<digits;displayWorkingCount++)
134     {
135         cout<<displayWorkingNumber/(int)pow((float)decimalSystem,displayWorkingDigits - 1);
136         cout<<" ";
137         displayWorkingNumber = displayWorkingNumber%(int)pow((float)decimalSystem,displayWorkingDigits - 1);
138         displayWorkingDigits = displayWorkingDigits - 1;
139     }
140     
141     /*用while循环实现*/
142     /*
143     int displayWorkingNumber = number;
144     int displayWorkingDigits = digits;
145     int displayWorkingCount = 0;
146 
147     while(displayWorkingCount < digits)
148     {
149         cout<<displayWorkingNumber/(int)pow((float)decimalSystem,displayWorkingDigits - 1);
150         cout<<" ";
151         displayWorkingNumber = displayWorkingNumber%(int)pow((float)decimalSystem,displayWorkingDigits - 1);
152         displayWorkingDigits = displayWorkingDigits - 1;
153         displayWorkingCount = displayWorkingCount + 1;
154     }
155     */
156 
157     /*用do-while循环实现*/
158     /*
159     int displayWorkingNumber = number;
160     int displayWorkingDigits = digits;
161     int displayWorkingCount = 0;
162     do
163     {
164         cout<<displayWorkingNumber/(int)pow((float)decimalSystem,displayWorkingDigits - 1);
165         cout<<" ";
166         displayWorkingNumber = displayWorkingNumber%(int)pow((float)decimalSystem,displayWorkingDigits - 1);
167         displayWorkingDigits = displayWorkingDigits - 1;
168         displayWorkingCount = displayWorkingCount + 1;
169     }while (displayWorkingCount < digits);
170     */
171     cout<<endl;
172     return 0;
173 }
174 
175 
176 /*方法2-C++实现代码*/
177 /*
178 int DisplayNumberByDigits(IN const int number,IN const int digits,IN const int decimalSystem)
179 {
180     cout<<"该数字从左至右位置上的数字依次为:";
181 
182     int displayWorkingNumber = number;
183     int displayWorkingDigits = digits;
184     int digitsArray[10];//数组个数声明为10的原因:int型数据,最大值为2147483647,10位数字。
185     int displayWorkingCount;
186 
187     for(displayWorkingCount = 0;displayWorkingCount < digits;displayWorkingCount++)
188     {
189         digitsArray[displayWorkingDigits -1] = displayWorkingNumber%decimalSystem;
190         displayWorkingNumber = displayWorkingNumber/decimalSystem;
191         displayWorkingDigits = displayWorkingDigits - 1;
192     }
193     for(displayWorkingCount = 0;displayWorkingCount <digits;displayWorkingCount++)
194     {
195         cout<<digitsArray[displayWorkingCount];
196         cout<<" ";
197     }
198     cout<<endl;
199     return 0;
200 }
201 */

 执行结果

 

 

 

有关(C++)读取一个输入的int型十进制数字的位数,并正序输出每个位上的值(不同数位的值用1个空格字符间隔)的更多相关文章

  1. ruby - 如何从 ruby​​ 中的字符串运行任意对象方法? - 2

    总的来说,我对ruby​​还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用

  2. Ruby 解析字符串 - 2

    我有一个字符串input="maybe(thisis|thatwas)some((nice|ugly)(day|night)|(strange(weather|time)))"Ruby中解析该字符串的最佳方法是什么?我的意思是脚本应该能够像这样构建句子:maybethisissomeuglynightmaybethatwassomenicenightmaybethiswassomestrangetime等等,你明白了......我应该一个字符一个字符地读取字符串并构建一个带有堆栈的状态机来存储括号值以供以后计算,还是有更好的方法?也许为此目的准备了一个开箱即用的库?

  3. ruby-on-rails - 在 Rails 中将文件大小字符串转换为等效千字节 - 2

    我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,

  4. ruby-on-rails - unicode 字符串的长度 - 2

    在我的Rails(2.3,Ruby1.8.7)应用程序中,我需要将字符串截断到一定长度。该字符串是unicode,在控制台中运行测试时,例如'א'.length,我意识到返回了双倍长度。我想要一个与编码无关的长度,以便对unicode字符串或latin1编码字符串进行相同的截断。我已经了解了Ruby的大部分unicode资料,但仍然有些一头雾水。应该如何解决这个问题? 最佳答案 Rails有一个返回多字节字符的mb_chars方法。试试unicode_string.mb_chars.slice(0,50)

  5. ruby - 将差异补丁应用于字符串/文件 - 2

    对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl

  6. ruby-on-rails - Rails 常用字符串(用于通知和错误信息等) - 2

    大约一年前,我决定确保每个包含非唯一文本的Flash通知都将从模块中的方法中获取文本。我这样做的最初原因是为了避免一遍又一遍地输入相同的字符串。如果我想更改措辞,我可以在一个地方轻松完成,而且一遍又一遍地重复同一件事而出现拼写错误的可能性也会降低。我最终得到的是这样的:moduleMessagesdefformat_error_messages(errors)errors.map{|attribute,message|"Error:#{attribute.to_s.titleize}#{message}."}enddeferror_message_could_not_find(obje

  7. ruby - 如何以所有可能的方式将字符串拆分为长度最多为 3 的连续子字符串? - 2

    我试图获取一个长度在1到10之间的字符串,并输出将字符串分解为大小为1、2或3的连续子字符串的所有可能方式。例如:输入:123456将整数分割成单个字符,然后继续查找组合。该代码将返回以下所有数组。[1,2,3,4,5,6][12,3,4,5,6][1,23,4,5,6][1,2,34,5,6][1,2,3,45,6][1,2,3,4,56][12,34,5,6][12,3,45,6][12,3,4,56][1,23,45,6][1,2,34,56][1,23,4,56][12,34,56][123,4,5,6][1,234,5,6][1,2,345,6][1,2,3,456][123

  8. ruby - 什么是填充的 Base64 编码字符串以及如何在 ruby​​ 中生成它们? - 2

    我正在使用的第三方API的文档状态:"[O]urAPIonlyacceptspaddedBase64encodedstrings."什么是“填充的Base64编码字符串”以及如何在Ruby中生成它们。下面的代码是我第一次尝试创建转换为Base64的JSON格式数据。xa=Base64.encode64(a.to_json) 最佳答案 他们说的padding其实就是Base64本身的一部分。它是末尾的“=”和“==”。Base64将3个字节的数据包编码为4个编码字符。所以如果你的输入数据有长度n和n%3=1=>"=="末尾用于填充n%

  9. ruby - 将数组的内容转换为 int - 2

    我需要读入一个包含数字列表的文件。此代码读取文件并将其放入二维数组中。现在我需要获取数组中所有数字的平均值,但我需要将数组的内容更改为int。有什么想法可以将to_i方法放在哪里吗?ClassTerraindefinitializefile_name@input=IO.readlines(file_name)#readinfile@size=@input[0].to_i@land=[@size]x=1whilex 最佳答案 只需将数组映射为整数:@land边注如果你想得到一条线的平均值,你可以这样做:values=@input[x]

  10. ruby - 检查 "command"的输出应该包含 NilClass 的意外崩溃 - 2

    为了将Cucumber用于命令行脚本,我按照提供的说明安装了arubagem。它在我的Gemfile中,我可以验证是否安装了正确的版本并且我已经包含了require'aruba/cucumber'在'features/env.rb'中为了确保它能正常工作,我写了以下场景:@announceScenario:Testingcucumber/arubaGivenablankslateThentheoutputfrom"ls-la"shouldcontain"drw"假设事情应该失败。它确实失败了,但失败的原因是错误的:@announceScenario:Testingcucumber/ar

随机推荐