2011NOIP普及组真题 1. 数字反转

线上OJ:

一本通:http://ybt.ssoier.cn:8088/problem_show.php?pid=1953

核心思想:

本题可以直接对字符串 处理,也可以 直接对 int 进行处理

int的范围是 -2,147,483,648 到 2,147,483,647,正好覆盖题中的 -1,000,000,000 ≤ N≤ 1,000,000,000

字符串处理方法

1、如果是0,直接输出0

2、如果是负数,先把负号输出,然后把剩余的字符串翻转

3、反转可使用 reverse(s.begin()+i, s.end()) , i 表示从第 i 位到末尾进行取反

4、输出时采用 substr(i, len-i) 表示从字符串第 i 位开始输出,输出长度为 len-i

题解代码:
cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

string s;
int len;

void prt(int i) // i:从s[i]开始翻转
{
    reverse(s.begin() + i, s.end()); // 从第 i 位到末尾进行取反

    while(s[i] == '0')  i++;  // 跳过取反后的前导 0

    cout << s.substr(i, len-i); // 从第i位开始输出,输出长度为 len - i
}

// 字符串方法
int main()
{
    cin >> s;
    len = s.size();
    if( s == "0" )  cout << '0'; // 如果是0,直接输出0
    else
    {
        if( s[0] == '-' )  // 如果是负数
        {
            cout << '-';   // 先输出负号
            prt(1);        // ,然后从 s[1]开始翻转
        }
        else  prt(0); // 否则,就直接从 s[0]开始翻转
    }

    return 0;
}
对 int 的处理方法

1、先处理负号

2、数字反向采用的方法与读入字符转成数字的方法类似,只是字符不是读入,而是自己 求余 获得

题解代码:
cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

int n, ans = 0;

int main()
{
    cin >> n;
    if(n < 0)
    {
        cout << '-';
        n = -n;
    }

    while(n)  // 类似读入字符"123"时将其转化为数字123的处理方法。只是字符不是读入,而是自己求余获得
    {
        ans = ans * 10 + n % 10;
        n /= 10;
    }
    cout << ans << endl;
    return 0;
}
相关推荐
Vect__2 小时前
基于线程池从零实现TCP计算器网络服务
c++·网络协议·tcp/ip
草履虫建模5 小时前
力扣算法 1768. 交替合并字符串
java·开发语言·算法·leetcode·职场和发展·idea·基础
naruto_lnq7 小时前
分布式系统安全通信
开发语言·c++·算法
Jasmine_llq7 小时前
《P3157 [CQOI2011] 动态逆序对》
算法·cdq 分治·动态问题静态化+双向偏序统计·树状数组(高效统计元素大小关系·排序算法(预处理偏序和时间戳)·前缀和(合并单个贡献为总逆序对·动态问题静态化
爱吃rabbit的mq8 小时前
第09章:随机森林:集成学习的威力
算法·随机森林·集成学习
(❁´◡`❁)Jimmy(❁´◡`❁)8 小时前
Exgcd 学习笔记
笔记·学习·算法
YYuCChi9 小时前
代码随想录算法训练营第三十七天 | 52.携带研究材料(卡码网)、518.零钱兑换||、377.组合总和IV、57.爬楼梯(卡码网)
算法·动态规划
CSDN_RTKLIB9 小时前
【四个场景测试】源文件编码UTF-8 BOM
c++
不能隔夜的咖喱9 小时前
牛客网刷题(2)
java·开发语言·算法
VT.馒头9 小时前
【力扣】2721. 并行执行异步函数
前端·javascript·算法·leetcode·typescript