为什么这道题直接按顺序放会有问题?求hack。
如果不懂可以看代码qwq
#include<bits/stdc++.h>
using namespace std;
const int maxn=1e3+10;
int arr[maxn][maxn],ans[maxn][maxn];
int vis[maxn][maxn],cnt[maxn][maxn];
int main(){
int n,m;
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
scanf("%d",&arr[i][j]);
cnt[i][arr[i][j]]++;
}
}
for(int k=1;k<=n;k++){
for(int i=1;i<=n;i++){
for(int j=1;j<=m&&cnt[i][k];j++){
if(vis[k][j]||ans[i][j]) continue;
else{
ans[i][j]=k;
cnt[i][k]--;
vis[k][j]=1;
}
}
}
}
printf("Yes\n");
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
printf("%d ",ans[i][j]);
}
printf("\n");
}
}