当前位置:   article > 正文

数字反转(升级版) 洛谷P1553_p1553数字反转(升级版)

p1553数字反转(升级版)

题目描述

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

这次与 NOIp2011 普及组第一题不同的是:这个数可以是小数,分数,百分数,整数。

  • - 整数反转是将所有数位对调。
  • - 小数反转是把整数部分的数反转,再将小数部分的数反转,不交换整数与小数部分。
  • - 分数反转是把分母的数反转,再把分子的数反转,不交换分子与分母。
  • - 百分数的分子一定是整数,百分数只改变数字部分。
  • 输入格式
  • 一个实数 s
  • 输出格式
  • 一个实数,即 s 的反转数

 输入与输出

样例输入样例输出
50874622647805
600.0846.48
700/277/72
8670%768%

提示

【数据范围】

  • 对于 25% 的数据,s 是整数,不大于 20 位;
  • 对于 25% 的数据,s 是小数,整数部分和小数部分均不大于 10 位;
  • 对于 25% 的数据,s 是分数,分子和分母均不大于 10 位;
  • 对于 25% 的数据,s 是百分数,分子不大于 19 位。

【数据保证】

  • 对于整数翻转而言,整数原数和整数新数满足整数的常见形式,即除非给定的原数为零,否则反转后得到的新数和原来的数字的最高位数字不应为零。
  • 对于小数翻转而言,其小数点前面部分同上,小数点后面部分的形式,保证满足小数的常见形式,也就是末尾没有多余的 $0$(小数部分除了 $0$ 没有别的数,那么只保留 $1$ 个 $0$。若反转之后末尾数字出现 $0$,请省略多余的 $0$)
  • 对于分数翻转而言,分数不约分,分子和分母都不是小数。输入的分母不为 $0$。与整数翻转相关规定见上。
  • 对于百分数翻转而言,见与整数翻转相关内容。
  • 数据不存在负数。
    1. #include<iostream>
    2. #include<string>
    3. using namespace std;
    4. int main()
    5. {
    6. string s;
    7. char p = 0;//放符号
    8. int cnt = 0;
    9. cin >> s;
    10. for (int i = 0; i < s.size(); i++)
    11. {
    12. if (s[i] >= '0' && s[i] <= '9') cnt++;//记录第一个数长度
    13. else //遇到符号,记录,跳出
    14. {
    15. p = s[i];
    16. break;
    17. }
    18. }
    19. int x = cnt;//记下第一个数末后一个的位置,也就是符号的位置,如果是分数或小数就要用
    20. cnt--;
    21. while (s[cnt] == '0' && cnt > 0) cnt--;//去除多余前导0;
    22. for (int i = cnt; i >= 0; i--)//输出第一个数
    23. cout << s[i];
    24. if (p == 0) return 0;//无符号return 0
    25. else
    26. if (p == '%') { cout << p; return 0; }
    27. else cout << p;//其他继续
    28. int m = s.size() - 1;
    29. while (s[x + 1] == '0' && x < m - 1) x++;//去除末尾0
    30. while (s[m] == '0' && m > x + 1) m--; //去除多余前导0
    31. for (int i = m; i > x; i--)//输出第二个数
    32. cout << s[i];
    33. return 0;
    34. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/程序质量控制师/article/detail/60507
推荐阅读
相关标签
  

闽ICP备14008679号