C++简洁代码:

提取不重复的整数

http://www.nowcoder.com/questionTerminal/253986e66d114d378ae8de2e6c4577c1

C++简洁代码:

#include<bits/stdc++.h>
using namespace std;

int main() {
    int nums; cin >> nums;
    string str = to_string(nums);
    unordered_set<char> set;
    reverse(str.begin(), str.end());
    string res;
    for(char c : str) 
        if(set.count(c) != 1) {
            res += c;
            set.insert(c);
        }
    cout << stoi(res) << endl;
    return 0;
}
全部评论
set.count(c)==0更符合第一逻辑感觉
点赞 回复 分享
发布于 2024-01-31 08:56 陕西
还有reverse,了解了
点赞 回复 分享
发布于 2024-01-31 08:42 陕西
为什么加入了set.insert(c)才res才没有重复数字;去掉set.insert(c)的话,res就还有重复数字了?
点赞 回复 分享
发布于 2023-08-15 16:06 广东
为什么要引入unorderd_set 去重? 直接用string的find不就可以啦? 是不是因为find返回的是size_t, 无符号整型,导致无法判断是否小于0啊?哈哈
点赞 回复 分享
发布于 2021-09-13 13:28
这for循环怎么长这样
点赞 回复 分享
发布于 2021-08-10 12:06
thanks a lot!
点赞 回复 分享
发布于 2021-04-08 16:33

相关推荐

05-09 13:22
门头沟学院 Java
点赞 评论 收藏
分享
评论
43
8
分享

创作者周榜

更多
牛客网
牛客企业服务