数字反转 NOIp普及组2011
当数字位数不确定时,如何反转呢?
本文为博客园ShyButHandsome原创作品,转载请注明出处
使用右侧目录快速浏览文章
题目描述
给定一个整数,请将该数各个位上数字反转得到一个新数。
新数也应满足整数的常见形式,即除非给定的原数为零,否则反转后得到的新数的最高位数字不应为零。
输入格式
一个整数\(N\)。
输出格式
一个整数,表示反转后的新数。
说明/提示
\(-1,000,000,000 \leq N \leq 1,000,000,000\) 。
分析
这题虽然给出了\(N\)的范围,但并没有给出确定的位数
没有说是一位数、两位数或者是三位数
如果给出位数那倒好办了int hun, ten, sig一气呵成
(可以将给出位数的每一位都用一个变量来储存,实在不行开个数组)
假如没有给出范围,你不知道该开多大的数组,怎么办?
方法一:给他一个无法拒绝的理由
注:"给他一个无法拒绝的理由"——《教父》中的"经典台词"
既然我不知道开多大,那我就使劲开咯
开一个超级大的数组,每一个元素对应一位
如:
int very_very_big[9999999] // 记得开在函数外但这样就造成了"假想无穷大"
真遇上奇葩数据得凉
方法二:"临时"和"总"
使用一个变量临时地储存每一位
然后在循环外定义一个变量用来累加(累乘)
只要每次在存入当前这位数时
将这个定义在循环外的变量 \(\times 10\)。
来腾出一个"个位"给当前这位数就可以了
比如:
现在给你一个数(这是一个数,我用空格分开了每一位,方便观察)
\]
int new_num = 0;
now = 4;
new_num = new_num * 10 + now // new_num = 0 * 10 + 4 = 4
\]
\]
now = 3;
new_num = 4 * 10 + 3;
\]
但,似乎还有个问题
我不知道有多少位数,那我的循环怎么结束?
遇到循环次数不确定时
我们首先要考虑while()循环
但无论是什么循环,都需要找到一个跳出循环的条件
那,什么样的条件合适呢?
标志flag,就是一个合适的条件
flag 无特殊含义
当达到临界条件时,这个flag会改变
flag就两种类型true or flase
不要去关注它的值
比如:
从\(1\)到\(9\)
for (int i = 1; i <= 9; i++)
当
i > 9时,flag倒下,条件不成立
你乍一看可能觉得我这是废话,其实不然
只是这种计时器类型的临界条件比较好找罢了
你不用去找别的,答案十分明确
但,别的类型呢?
关键就是要找,达到成你目的时会变化的flag
就像CE找地址
CE: Cheat Engine的缩写,一款非常优秀的内存地址查找软件
你通过不断改变值,总能找到你想要的那个地址
CE这里的flag就是随着值变动而变动为正确值
比如:
- 你把那个值改为了\(123\)
- 地址列表中没有改变的值、或者变化后值不是\(123\)的值就会被剔除
不满足条件则出局out
这是排除法
好的,那么问题来了
现在给你一个数(这是一个数,我用空格分开了每一位,方便观察)
\]
现在位数是\(9\)。
指向\(9\)。
从\(9\)到\(1\)。
从\(1\)到\(9\)。
每次到最高位/最低位的距离都在变化
那只要让距离最高位/最低位的距离一定
就改变了距离到最高位/最低位的距离改变这个flag
欸,别忘了前导零的存在!
这玩意你加多少个都没问题
而当你指向前导零时
你到最高位/最低位的距离都是不变的
欧耶!条件找到了!
最终指向前导零的时候就是到达了最高位
可是问题又来了,这个指向每一位的操作怎么模拟?
指向每一位的操作可以/10和%10来模拟
对一个整形/10可以减少一位
而%10可以取出最低位
特别说明:%
根据在C++中取余运算的定义:
如果\(m\)和\(n\)是整数且\(n \neq 0\)。
则表达式\((m/n)*n + m%n\)的运算结果与\(m\)相等
隐含的意思是:如果\(m%n \neq 0\),则它的符号与\(m\)相同。
除了\(-m\)导致的溢出的特殊情况外,
其他时候
m % (-n) = m % n
(-m) % n = -(m % n)
也就是说,你可以不用担心负数的问题了
那,如何指向一位位地指向前导零呢?
因为每次/10距离都会减少一位
所以当数字长度不断减小直到为\(0\)时,此时指向前导零
即,已经从低到高一位位地遍历了整个数
任务完成,退出循环!
代码实现
// 来源:自己写的
// 作者:@ShyButHandsome
#include<bits/stdc++.h>
using namespace std;
int main(void)
{
long long num;
cin >> num;
long long new_num = 0;
int n = 1;
int count = 0;
while(num)
{
int each_bit = num % 10;
new_num = new_num * 10 + each;
num /= 10;
}
cout << new_num;
return 0;
}
总结
这样思考下来
我们收获了什么?
- 将一个定义域内变量累加到定义域外的思想
flag的选择%的使用和/一样,是带号的
参考资料
《C++ Primer》
我是ShyButHandsome,一个名字与实际截然相反的OI蒟蒻,如果你觉得这篇文章写的还行的话,不妨点点推荐?
数字反转 NOIp普及组2011的更多相关文章
- [NOIP普及组2011]装箱问题
目录 链接 博客链接 题目链接 题目内容 题目描述 格式 输入 输出 样例 输入 输出 前缀知识 题解 题目名称:装箱问题 来源:2011年NOIP普及组 链接 博客链接 CSDN 洛谷博客 题目链接 ...
- [NOIp普及组2011]瑞士轮
洛谷题目链接:瑞士轮 题目背景 在双人对决的竞技性比赛,如乒乓球.羽毛球.国际象棋中,最常见的赛制是淘汰赛和循环赛.前者的特点是比赛场数少,每场都紧张刺激,但偶然性较高.后者的特点是较为公平,偶然性较 ...
- 2016.9.3初中部上午NOIP普及组比赛总结
2016.9.3初中部上午NOIP普及组比赛总结 链接:https://jzoj.net/junior/#contest/home/1339 这次真爽,拿了个第四!(我还被班主任叫过去1小时呢!) 进 ...
- 2016.10.7初中部上午NOIP普及组比赛总结
2016.10.7初中部上午NOIP普及组比赛总结 这次的题还可以,重新入了比赛的前十. 进度: 比赛:90+10+70+30=200 改题:AC+AC+AC+AC=AK 找试场 这题很简单,但是被欺 ...
- 2016.10.6初中部上午NOIP普及组比赛总结
2016.10.6初中部上午NOIP普及组比赛总结 中了病毒--病毒--病毒-- 进度: 比赛:AC+0+0+20=120 改题:AC+0+AC+20=220 Stairs 好--简--单!递推就过了 ...
- 2016.9.24初中部上午NOIP普及组比赛总结
2016.9.24初中部上午NOIP普及组比赛总结 2016.09.24[初中部 NOIP普及组 ]模拟赛 其实这次我没比赛,早上去参加亲子活动去了. 不过在下午我做完了所有的题,感觉还好. 进度 现 ...
- 2321. 【NOIP普及组T1】方程
2321. [NOIP普及组T1]方程 时间限制: 1000 ms 空间限制: 262144 KB 题目描述
- [NOIP普及组2001]最大公约数和最小公倍数问题
目录 链接 博客链接 题目链接 题目内容 题目描述 格式 输入 输出 数据 样例 输入 输出 说明 题目名称:最大公约数和最小公倍数问题 来源:2001年NOIP普及组 链接 博客链接 CSDN 洛谷 ...
- 2016.8.15上午纪中初中部NOIP普及组比赛
2016.8.15上午纪中初中部NOIP普及组比赛 链接:https://jzoj.net/junior/#contest/home/1333 这次比赛不怎么好,因为这套题目我并不是很擅长. 可同学们 ...
随机推荐
- 利用动态资源分配优化Spark应用资源利用率
背景 在某地市开展项目的时候,发现数据采集,数据探索,预处理,数据统计,训练预测都需要很多资源,现场资源不够用. 目前该项目的资源3台旧的服务器,每台的资源 内存为128G,cores 为24 (co ...
- 微信小程序从开发至发布的流程
今天在公司将这几天开发的小程序,进行版本上线,在这里记录下. 首先,将微信开发工具里的代码上传到微信小程序平台里,如下所示 之后,在微信小程序平台进行审核提交,填写相应的信息即可,注意,审核提交分为紧 ...
- Canvas 使用及应用
Canvas canvas 是 HTML5 当中我最喜欢的所有新特性中我最喜欢的一个标签了.因为它太强大了,各种有意思的特效都可以实现. 1. canvas 的基本使用方法 - 它是一个行内块元素 - ...
- C#小游戏—钢铁侠VS太空侵略者
身为漫威迷,最近又把<钢铁侠>和<复仇者联盟>系列又重温了一遍,真的是印证了那句话:“读书百遍,其意自现”.看电影一个道理,每看一遍,都有不懂的感受~ 不知道大伙是不是也有同样 ...
- Object-Oriented Programming Summary Ⅱ
电梯作业总结博客 17373492 电梯,多线程学习中的 "HelloWorld",早在大一就有所耳闻,以至于在坐电梯的时候就思考过:电梯需要怎么写呢? 0. 前言: 偶然的机会, ...
- 读《Java并发编程的艺术》学习笔记(一)
接下来一个系列,是关于<Java并发编程的艺术>这本书的读书笔记以及相关知识点,主要是为了方便日后多次复习和防止忘记.废话不多说,直接步入主题: 第1章 并发编程的挑战 并发编程的目的是 ...
- python之嵌套 闭包 装饰器 global、nonlocal关键字
嵌套: 在函数的内部定义函数闭包: 符合开放封闭原则:在不修改源代码与调用方式的情况下为函数添加新功能 # global 将局部变量变成全局变量 num = 100 def fn1(): globa ...
- 深入理解Java之线程池(网络笔记)
原文链接:http://www.cnblogs.com/dolphin0520/p/3932921.html 附加:http://www.cnblogs.com/wxd0108/p/5479442.h ...
- 简单的节流函数throttle
在实际项目中,总会遇到一些函数频繁调用的情况,比如window.resize,mouseover,上传进度类似的触发频率比较高的函数,造成很大的性能损耗,这里可以使用节流函数来进行性能优化,主要是限制 ...
- openwrt 外挂usb 网卡 RTL8188CU 及添加 RT5572 kernel支持
RT5572 原来叫 Ralink雷凌 现在被 MTK 收购了,淘宝上买的很便宜50块邮,2.4 5G 双频.在 win10 上插了试试,果然是支持 5G.这上面写着 飞荣 是什么牌子,有知道的和我说 ...