1064 朋友数

Posted keep23456

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了1064 朋友数相关的知识,希望对你有一定的参考价值。

这道题很容易理解。我第一遍做的时候借助了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 朋友数的主要内容,如果未能解决你的问题,请参考以下文章

1064. 朋友数(20)

PAT 1064. 朋友数(20)

PAT Basic 1064 朋友数 (20 分)

1064 朋友数

1064 朋友数 (20 分)

PAT乙级1064 朋友数 (20 分)