1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
#include <iostream>
#include <algorithm>
using namespace std;
int n, t[300000],t2[300000],t3[300000],k,l,s[300001];
int main()
{
   cin>>n;

   for(int i=0;i<n;i++)cin>>t[i];

   sort(t,t+n);

   k=t[0];
   t2[0]=t[0]; t3[0]=1;
   for(int i=1;i<n;i++)
   {
     if(t[i]==k) t3[l]++;
     else {l++; t2[l]=t[i]; t3[l]++; k=t[i];}
   }





    for(int i=1;i<=n;i++)
    {

        for(int j=0;j<=l;j++)
      {

if(t3[j]>=i && t3[j]%i==0) s[i]+=t3[j];
        else if(t3[j]>=i) s[i]+=i*(t3[j]/i); }
    }

    for(int i=1;i<=n;i++)
    {
        cout<<s[i]<<" ";
    }
    return 0;
}