給定乙個數,請將該數各個位上數字反轉得到乙個新數。
這次與noip2011普及組第一題不同的是:這個數可以是小數,分數,百分數,整數。整數反轉是將所有數字對調;小數反轉是把整數部分的數反轉,再將小數部分的數反轉,不交換整數部分與小數部分;分數反轉是把分母的數反轉,再把分子的數反轉,不交換分子與分母;百分數的分子一定是整數,百分數只改變量字部分。整數新數也應滿足整數的常見形式,即除非給定的原數為零,否則反轉後得到的新數的最高位數字不應為零;小數新數的末尾不為0(除非小數部分除了0沒有別的數,那麼只保留1個0);分數不約分,分子和分母都不是小數(約分滴童鞋抱歉了,不能過哦。輸入資料保證分母不為0),本次沒有負數。
題目描述
給定乙個數,請將該數各個位上數字反轉得到乙個新數。
這次與noip2011普及組第一題不同的是:這個數可以是小數,分數,百分數,整數。
整數反轉是將所有數字對調。
小數反轉是把整數部分的數反轉,再將小數部分的數反轉,不交換整數部分與小數部分。
分數反轉是把分母的數反轉,再把分子的數反轉,不交換分子與分母。
百分數的分子一定是整數,百分數只改變量字部分。
輸入格式
乙個數 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個資料)
資料保證:
資料不存在負數。
我的解題方法很笨重但是很易懂,慢慢看很容易。把整數、小數、分數、百分數分成4個函式。
#include
#include
#include
#include
#include
using
namespace std;
void
fraction
(string str)
;void
percent
(string str)
;void
decimal
(string str)
;void
integer
(string str)
;int
main()
else
if(str.
find
("%"
)!= string::npos)
else
if(str.
find
("/"
)!= string::npos)
else
return0;
}void
decimal
(string str)
}for
(int i1 = st; i1 < s1.
size()
; i1++
)for
(int i2 = s2.
size()
-1; i2 >=
0; i2--)}
// cout << e2 << endl;
for(
int i =
0; i < e2 +
1; i++
)// 補零
if(ans2.
size()
==0) ans2 =
"0";
cout << ans1 <<
"."<< ans2 << endl;
}void
integer
(string str)
}// cout << st << endl;
for(
int i = st; i < str.
size()
; i++
) cout << ans;
}void
percent
(string s)
void
fraction
(string str)
}for
(int i1 = st; i1 < s1.
size()
; i1++
)// for (int i2 = s2.size() - 1; i2 >= 0; i2--)
// // }
// // cout << e2 << endl;
// for (int i = 0; i < e2 + 1; i++)
// cout << ans1 <<
"/";
// 補零
// if (ans2.size() == 0)
// ans2 = "0";
integer
(s2)
;return
;}
洛谷P1553 數字反轉(公升級版)
題目描述 給定乙個數,請將該數各個位上數字反轉得到乙個新數。這次與noip2011普及組第一題不同的是 這個數可以是小數,分數,百分數,整數。整數反轉是將所有數字對調 小數反轉是把整數部分的數反轉,再將小數部分的數反轉,不交換整數部分與小數部分 分數反轉是把分母的數反轉,再把分子的數反轉,不交換分子...
洛谷 P1553 數字反轉(公升級版)
題目描述 給定乙個數,請將該數各個位上數字反轉得到乙個新數。這次與noip2011普及組第一題不同的是 這個數可以是小數,分數,百分數,整數。整數反轉是將所有數字對調 小數反轉是把整數部分的數反轉,再將小數部分的數反轉,不交換整數部分與小數部分 分數反轉是把分母的數反轉,再把分子的數反轉,不交換分子...
洛谷 P1553 數字反轉(公升級版)
使用string中的reverse,find first not of函式 翻轉函式。把string型別的字串翻轉一次 常用的格式 reverse str.begin str.end 返回在字串中首次出現的不匹配str任何字元的首字元索引 當然這個函式有很多用法,這裡去除前導0的語句是 str st...