P1553数字反转(升级版)

给定一个数,请将该数各个位上数字反转得到一个新数。

这次与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;
}`

你可能感兴趣的:(P1553数字反转(升级版))