數字反轉(公升級版)

2021-10-01 04:18:33 字數 1643 閱讀 5031

題目描述

給定乙個數,請將該數各個位上數字反轉得到乙個新數。

這次與noip2011普及組第一題不同的是:這個數可以是小數,分數,百分數,整數。整數反轉是將所有數字對調;小數反轉是把整數部分的數反轉,再將小數部分的數反轉,不交換整數部分與小數部分;分數反轉是把分母的數反轉,再把分子的數反轉,不交換分子與分母;百分數的分子一定是整數,百分數只改變量字部分。整數新數也應滿足整數的常見形式,即除非給定的原數為零,否則反轉後得到的新數的最高位數字不應為零;小數新數的末尾不為0(除非小數部分除了0沒有別的數,那麼只保留1個0);分數不約分,分子和分母都不是小數(約分滴童鞋抱歉了,不能過哦。輸入資料保證分母不為0),本次沒有負數。

輸入格式

乙個數s

輸出格式

乙個數,即s的反轉數

輸入輸出樣例

輸入 #1

5087462

輸出 #1

2647805

輸入 #2

600.084

輸出 #2

6.48

輸入 #3

700/27

輸出 #3

7/72

輸入 #4

8670%

輸出 #4

768%

說明/提示

所有資料:25%s是整數,不大於20位

25%s是小數,整數部分和小數部分均不大於10位

25%s是分數,分子和分母均不大於10位

25%s是百分數,分子不大於19位

(20個資料)

#include

#include

using

namespace std;

intmain()

}int x=b;

//記下第乙個數末後乙個的位置,也就是符號的位置,如果是分數或小數就要用

b--;while

(s[b]

=='0'

&&b>0)

b--;//去除多餘前導0

for(i=b;i>=0;

--i)

//輸出第乙個數

cout<(a==0)

return0;

//無符號return 0

else

if(a==

'%')

else

cout

int m=s.

length()

-1;while

(s[x+1]

=='0'

&&xx++

;//去除末尾0

while

(s[m]

=='0'

&&m>x+1)

m--;//去除多餘前導0

for(i=m;i>x;

--i)

//輸出第二個數

cout<;return0;

}

P1553 數字反轉(公升級版)

給定乙個數,請將該數各個位上數字反轉得到乙個新數。這次與noip2011普及組第一題不同的是 這個數可以是小數,分數,百分數,整數。整數反轉是將所有數字對調 小數反轉是把整數部分的數反轉,再將小數部分的數反轉,不交換整數部分與小數部分 分數反轉是把分母的數反轉,再把分子的數反轉,不交換分子與分母 百...

P1553 數字反轉(公升級版)

題目鏈結 題目描述 給定乙個數,請將該數各個位上數字反轉得到乙個新數。這次與noip2011普及組第一題不同的是 這個數可以是小數,分數,百分數,整數。整數反轉是將所有數字對調 小數反轉是把整數部分的數反轉,再將小數部分的數反轉,不交換整數部分與小數部分 分數反轉是把分母的數反轉,再把分子的數反轉,...

P1553 數字反轉(公升級版)

題目描述 給定乙個數,請將該數各個位上數字反轉得到乙個新數。這次與noip2011普及組第一題不同的是 這個數可以是小數,分數,百分數,整數。整數反轉是將所有數字對調 小數反轉是把整數部分的數反轉,再將小數部分的數反轉,不交換整數部分與小數部分 分數反轉是把分母的數反轉,再把分子的數反轉,不交換分子...