题目描述
给定一个数,请将该数各个位上数字反转得到一个新的数。
这次与NOIp2011普及组第一题不同的是:这个数可以是小数,分数,百分数,整数。
-
整数反转是将所有数位对调。
-
小数反转是把整数部分的数反转,再将小数部分的数反转,不交换整数部分与小数部分。
-
分数反转是把分母的数反转,再把分子的数反转,不交换分子与分母。
-
百分数的分子一定是整数,百分数只改变数字部分。
输入格式
一个数 ss
输出格式
一个数,即 ss 的反转数
分析:
先根据符号分为两部分,将符号前的部分反序输出,在根据符号进行后面数字的反转。
(1)如果没有符号,直接反序输出。
(2)如果是‘%’,直接将前面的数进行反序输出,在将符号输出就可以
(3)如果是‘.’和‘/’都是将后面的数字进行反序输出
要考虑几个地方,第一部分如果后面是0,要进行去0,第二部分,要去除前面的0.
#include<bits/stdc++.h>
using namespace std;
int main() {
string s;
char c='0';//用来存放符号
int t = 0;
cin >> s;
for (int i = 0; i < s.length(); i++) {
if (s[i] >= '0' && s[i] <