给定一个数,请将该数各个位上数字反转得到一个新数。
这次与NOIp2011普及组第一题不同的是:这个数可以是小数,分数,百分数,整数。整数反转是将所有数位对调;小数反转是把整数部分的数反转,再将小数部分的数反转,不交换整数部分与小数部分;分数反转是把分母的数反转,再把分子的数反转,不交换分子与分母;百分数的分子一定是整数,百分数只改变数字部分。整数新数也应满足整数的常见形式,即除非给定的原数为零,否则反转后得到的新数的最高位数字不应为零;小数新数的末尾不为0(除非小数部分除了0没有别的数,那么只保留1个0);分数不约分,分子和分母都不是小数(约分滴童鞋抱歉了,不能过哦。输入数据保证分母不为0),本次没有负数。
题目描述
给定一个数,请将该数各个位上数字反转得到一个新数。
这次与NOIp2011普及组第一题不同的是:这个数可以是小数,分数,百分数,整数。
整数反转是将所有数位对调。
小数反转是把整数部分的数反转,再将小数部分的数反转,不交换整数部分与小数部分。
分数反转是把分母的数反转,再把分子的数反转,不交换分子与分母。
百分数的分子一定是整数,百分数只改变数字部分。
输入格式
一个数 s
输出格式
一个数,即 s 的反转数
重点:
此题考察的主要是去掉字符串的的前置和后置“0”
解题思路:
输入一串字符串
去掉字符串的前置后置“0”
若有**“.”** **“ /”** 就输出之前反转的数,接着继续进行新的字符串的反转
若遇到“%” 或者字符串的遍历结束,就结束反转并输出
记得特殊字符的输出
代码:`
include<bits/stdc++.h>
using namespace std;
int main()
{
string s;
char ch = ' ';
getline(cin,s);
int l;
for(int i = 0;i<s.size();i++)
{
if(s[i] == '/'||s[i] == '%'||s[i] == '.')
{
l = i;//统计字符串开头的数字字符(包括了特殊字符)
ch = s[i];//保存特殊字符
break;
}
}
if(ch == ' ')//整数的情况
{
l = s.size()-1;//实际字符串的长度
while(s[l] == '0'&&l > 0)l--;//此题最重要的操作————“去零”,即通过对忽略这些’0‘,从而达到“去零”
for(int i = l;i >= 0;i--)
{
cout<<s[i];
}
}
else
{
l -= 1;//减去特殊字符的长度
int k=l+2;//第二部分数字的下标
while(s[l] == '0'&&l > 0)l--;//同上
for(int i = l;i >= 0;i--)
{
cout<<s[i];//转换操作
}
cout<<ch;
int len = s.size()-1;//整体长度
while(s[k] == '0'&&len > k)k++;//去除前置零
while(s[len] == '0'&&len > k)len--;//去除后置零(不慎跌坑)
for(int i = len;i >= k;i--)
{
cout<<s[i];//转换操作
}
}
cout<<endl;
return 0;
}`