首页 > 其他 > 详细

1064 朋友数

时间:2020-02-23 22:46:26      阅读:89      评论:0      收藏:0      [点我收藏+]

这道题很容易理解。我第一遍做的时候借助了map,没想到第二遍还是一样,哈哈哈。

但是map用的更娴熟了,开心。

#include<iostream>
#include<map>
using namespace std;
int main() {
    int n,t,cnt = 0;
    cin>>n;
    map<int,int> mp;
    while(n--) {
        scanf("%d",&t);
        int sum = 0;
        while(t != 0) {
            sum += t%10;
            t /= 10;
        }
        mp[sum]++;
    }
    cout<<mp.size()<<endl;
    for(auto it = mp.begin(); it != mp.end(); ++it) {
        if(it != mp.begin()) printf(" ");
        cout<<it->first;
    }
    return 0;
}

另外,这题应该借助 set(自排序+去重)更好。

#include<iostream>
#include<set>
using namespace std;

int main() {
    int n,t,cnt = 0;
    cin>>n;
    set<int> st;
    while(n--) {
        scanf("%d",&t);
        int sum = 0;
        while(t != 0) {
            sum += t%10;
            t /= 10;
        }
        st.insert(sum);
    }
    cout<<st.size()<<endl;
    for(auto it = st.begin(); it != st.end(); ++it) {
        if(it != st.begin()) printf(" ");
        cout<<*it;
    }
    return 0;
}

技术分享图片

 

1064 朋友数

原文:https://www.cnblogs.com/keep23456/p/12354360.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!