• P1553 数字反转(升级版)


    题目传送门

    #include<bits/stdc++.h>
    
    using namespace std;
    /**
    0.000009->0.9
    0.900000->0.000009
    00000.00000->0.0
    0/1230000->0/321不是0也不是0/0000321
    000000000->0
    1.00 -->1.0
    0%  --->0%
    */
    //是哪种?
    int getType(string a) {
        if (a.find('.') != a.npos) return 2;
        if (a.find('/') != a.npos) return 3;
        if (a.find('%') != a.npos) return 4;
        return 1;
    }
    
    int main() {
        string a;
        int i, p, end;
        cin >> a;
        if (a == "0") {
            printf("%d", 0);
            exit(0);
        }
        switch (getType(a)) {
            case 1:
                //去掉前导0
                i = a.size() - 1;
                while (a[i] == '0')i--;
                //输出
                if (i == -1) cout << 0;
                else
                    while (i >= 0) cout << a[i], i--;
                break;
            case 2:
                p = a.find('.');
                //输出整数部分
                i = p - 1;
                while (a[i] == '0')i--;
                //输出大吉
                //如果只有一个0
                if (i == -1) cout << 0;
                else while (i >= 0) cout << a[i], i--;
                //输出.
                cout << ".";
                //小数部分开始
                i = a.size() - 1;
                //跳过后导0
                end = p + 1;
                while (a[end] == '0')end++;
                if (i < end) cout << 0;
                else
                    //输出大吉
                    while (i >= end) cout << a[i], i--;
                break;
            case 3:
                p = a.find('/');
                //分子
                i = p - 1;
                while (a[i] == '0')i--;
                if (i == -1) cout << 0;
                    //输出大吉
                else while (i >= 0) cout << a[i], i--;
                //除号
                cout << "/";
                //分母
                i = a.size() - 1;
                //跳过前导0
                while (a[i] == '0')i--;
                //输出大吉
                while (i > p) cout << a[i], i--;
                break;
            case 4:
                //去掉前导0
                i = a.size() - 2;
                while (a[i] == '0')i--;
                if (i == -1) cout << 0;
                    //输出大吉
                else while (i >= 0) cout << a[i], i--;
                //输出%
                cout << "%";
                break;
        }
        return 0;
    }
    
  • 相关阅读:
    笔记
    创建和使用URL访问网上资源
    File
    event_1:事件注册
    3_3:创建 元素节点
    动态创建表格
    留言删除案例
    3_2:操作节点 [ 增 删 复制 ]
    5:to do list
    仿新浪下拉菜单
  • 原文地址:https://www.cnblogs.com/littlehb/p/15571137.html
Copyright © 2020-2023  润新知