リンクをクリックして、完全なソリューションの概要PAT B -AC
タイトル:
「フレンドカード番号」2つの整数番号と誰もが同じであるが、「友人の数」と呼ばれ、公共のこと、そのことならば = 6ので、1 + 2 + 3 = 5 + 1 51と123は、例えば、友人の数であり、図6は、彼らの友人のカード番号です。あなたは、彼らが持っているどのように多くの異なった友人のライセンス数に関する統計情報を必要とする整数のいくつかを考えます。
入力フォーマット:
最初の行の入力は、正の整数Nを与えられています 次に数字の間のスペースで区切られたNの正の整数の行を、与えられました。タイトルそのすべての数字が10未満確保。4。
出力形式:
まず、友人の異なるデジタル証明書番号の数、所与の第一の出力ラインと、友人のカード番号とその後の昇順で行を出力し、デジタル間隔スペース、行の終わりに余分なスペースを有していなくてもよいです。
サンプル入力:
8
123 899 51 998 27 33 36 12
出力例:
4
3 6 9 26
私のコード:
#include<iostream>
#include<cstdio>
#include<vector>
#include<string>
#include<set>
#include<map>
#include<algorithm>
#include<cmath>
#include<ctime>
#include<cstring>
#include<sstream>
using namespace std;
//有的时候题目是一起做的,所以会有不需要的头文件
int main()
{
set<int>friend_num;
int N;
cin>>N;
for(int i=0;i<N;i++)
{
int t;
cin>>t;
int sum=0;
while(t>0)
{
sum+=t%10;
t/=10;
}
friend_num.insert(sum);
}
cout<<friend_num.size()<<endl;;
while(1)
{
printf("%d",*friend_num.begin());
friend_num.erase(friend_num.begin());
if(friend_num.size())cout<<" ";
else return 0;
}
return 0;
}
注:直接計算し、すべての行、および必要性の例のように、2の同じ番号を持っていない3