数学反转加强版(逻辑模拟,细细读)

简介: 数学反转加强版(逻辑模拟,细细读)

题目描述



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


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


  • 整数反转是将所有数位对调。
  • 小数反转是把整数部分的数反转,再将小数部分的数反转,不交换整数部分与小数部分。
  • 分数反转是把分母的数反转,再把分子的数反转,不交换分子与分母。
  • 百分数的分子一定是整数,百分数只改变数字部分。


输入格式



一个数  s


输出格式



一个数,即 s  的反转数


输入输出样例



输入

5087462


输出

2647805


输入  

600.084


输出

6.48


输入  

700/27


输出

7/72


输入  

8670%


输出

768%


说明/提示



所有数据:25%s是整数,不大于20位


25%s是小数,整数部分和小数部分均不大于10位


25%s是分数,分子和分母均不大于10位


25%s是百分数,分子不大于19位


(20个数据)


数据保证:


  • 对于整数翻转而言,整数原数和整数新数满足整数的常见形式,即除非给定的原数为零,否则反转后得到的新数和原来的数字的最高位数字不应为零。
  • 对于小数翻转而言,其小数点前面部分同上,小数点后面部分的形式,保证满足小数的常见形式,也就是末尾没有多余的  0(小数部分除了  0 没有别的数,那么只保留  1 个   0。若反转之后末尾数字出现  0,请省略多余的 0 )
  • 对于分数翻转而言,分数不约分,分子和分母都不是小数。输入的分母不为0。与整数翻转相关规定见上。
  • 对于百分数翻转而言,见与整数翻转相关内容。


数据不存在负数。


直接模拟上,看代码。

#include<bits/stdc++.h>
using namespace std;
int main()
{
    string s;
    char p=0;//放符号 
    int cnt=0; 
    cin>>s;
    for(int i=0;i<s.size();i++)
    {
        if(s[i]>='0'&&s[i]<='9') 
    cnt++;//记录第一个数长度
        else    //遇到符号,记录,跳出 
        {
            p=s[i];
            break;
        } 
    }
    int x=cnt;//记下第一个数末后一个的位置,也就是符号的位置,如果是分数或小数就要用 
    cnt--;
    while(s[cnt]=='0'&&cnt>0)
   cnt--;//去除多余前导0; 
    for(int i=cnt;i>=0;i--)//输出第一个数 
       cout<<s[i];
    if(p==0) //'0'的整形值是48,而ascii码0代表空操作
  return 0;//无符号return 0 
    else
      if(p=='%')
     {
     cout<<p;
     return 0;
     } 
      else
     cout<<p;//其他继续 
    int m=s.size()-1;
    while(s[x+1]=='0'&&x<m-1) //至少存在一位 
  x++;//去除开头0 
    while(s[m]=='0'&&m>x+1) 
  m--; //去除多余尾0
    for(int i=m;i>x;i--)//输出第二个数 
        cout<<s[i];//懂了的给个赞吧,不要求收藏
}
相关文章
|
8月前
|
算法 Java
算法编程(十四):颠倒二进制位
算法编程(十四):颠倒二进制位
71 0
|
8月前
|
算法 Java
算法编程(三十):交替合并字符串
算法编程(三十):交替合并字符串
104 0
|
7月前
|
C语言
基于C语言的随机点名器设计
基于C语言的随机点名器设计
基于C语言的随机点名器设计
|
8月前
|
C语言 C++
异或运算的骚操作,由浅入深拿捏一类型的题
异或运算的骚操作,由浅入深拿捏一类型的题
159 1
|
C语言
《C语言初阶篇》听说你还不会for循环的变种写法?一文教你彻底搞懂循环语句!
《C语言初阶篇》听说你还不会for循环的变种写法?一文教你彻底搞懂循环语句!
236 0
|
算法
《零基础学算法》(第一讲)位运算的奇技淫巧
《零基础学算法》(第一讲)位运算的奇技淫巧
159 0
不用加减乘除怎么实现两个数相加?这种方法你想到了吗?
不用加减乘除怎么实现两个数相加?这种方法你想到了吗?
|
算法 C++
【每日算法Day 99】你们可能不知道只用20万赢到578万是什么概念
【每日算法Day 99】你们可能不知道只用20万赢到578万是什么概念
118 0
|
编解码 算法
关于位运算的巧妙性:小乖,你真的明白吗?
关于位运算的巧妙性:小乖,你真的明白吗?
学完链表,不去找几个经典例题巩固一下知识?链表的五大OJ经典例题,你会吗?不妨来看一看(知识剖析+图形理解)(上)
学完链表,不去找几个经典例题巩固一下知识?链表的五大OJ经典例题,你会吗?不妨来看一看(知识剖析+图形理解)
137 0
学完链表,不去找几个经典例题巩固一下知识?链表的五大OJ经典例题,你会吗?不妨来看一看(知识剖析+图形理解)(上)