分析
2021年CCCC天梯赛的一道问题。
使用一个数据结构存贮所有的数组及其出现的次数。
使用哈希表mp存储数组$vector< int\>$的映射关系。
将所有的结果进行排序,最终输出排序后的结果。
C++ 代码
#include<bits/stdc++.h>
using namespace std;
typedef vector<int> vi;
const int N = 1e4+10;
int n,m,x,idx;
struct node{ //数据结构
int co=0; //当前数组出现过多少次
vi v; //存储数组
bool operator<(const node& p)const{ //排序函数
if(co!=p.co) return co>p.co; //出现次数从大到小
for(int i=0;i<v.size();i++) //数组元素从小到大
{
if(v[i]!=p.v[i])
{
return v[i]<p.v[i];
}
}
}
}a[N];
map<vi,int> mp;
int main()
{
scanf("%d%d",&n,&m);
for(int i=0;i<n;i++)
{
vi temp;
for(int j=0;j<m;j++)
{
scanf("%d",&x);
temp.push_back(x);
}
if(!mp[temp]){ //哈希表中没有,就加入该数组
mp[temp]=++idx;
a[idx].v=temp;
a[idx].co=1;
}
else{ //哈希表中有,就令该数组的次数co++
a[mp[temp]].co++;
}
}
sort(a+1,a+1+idx); //进行排序
cout<<idx<<endl;
for(int i=1;i<=idx;i++)
{
cout<<a[i].co;
for(auto x:a[i].v)
cout<<" "<<x;
puts("");
}
return 0;
}