p1059明明的隨機數兩種方法
阿新 • • 發佈:2018-12-20
原題網址 在做這道題的時候剛開始想到的方法是初始化一個數組 然後將重複的數跳過 但是發現需要用捅排的思想來判斷有沒有出現過那個數 所以就出現了兩種輸出方式 但是核心思想都是開桶:
#include<bits/stdc++.h> using namespace std; int main() { int n,x,sum=0; int a[1000]; cin>>n; memset(a,0,sizeof(a)); for(int i=0;i<n;i++) { cin>>x; if(a[x]) continue; a[x]++; sum++; } cout<<sum<<endl; for(int i=0;i<1000;i++) { if(a[i]) cout<<i<<" "; } }
第二種是把x存到一個數組b[i]中去 然後因為初始化過 如果不等於0 就輸出 程式碼如下:
#include<bits/stdc++.h> using namespace std; int main() { int n,x,sum=0; int a[1000],b[1000]; cin>>n; memset(a,0,sizeof(a)); memset(b,0,sizeof(b)); for(int i=0;i<n;i++) { cin>>x; if(a[x]) continue; a[x]++; b[i]=x; sum++; } cout<<sum<<endl; sort(b,b+n); for(int j=0;j<1000;j++) { if(b[j]!=0) cout<<b[j]<<" "; } }
還有大佬的第三種方法
#include <bits/stdc++.h>
using namespace std;
set<int> s;
int main()
{
int n;
cin>>n;
while(n--)
{
int x;
cin>>x;
s.insert(x);
}
cout<<s.size()<<endl;
for(auto it=s.begin();it!=s.end();it++)
cout<<*it<<" ";
}
暫時…還看不太懂 不過馬上就能懂了!