题意:
称一个矩阵是下降矩阵,当且仅当矩阵的每一列都是严格下降的。
给定n*m的矩阵,问最少消去多少行,可以使得这个矩阵变为下降矩阵。
数据范围:n,m<=300
解法:
将问题变为计算最多保留多少行,满足保留的行是下降的.
发现如果两行相邻,那么下面的行一定每一格都小于上面的行,
也就是说行与行是可以比较的,
那么问题可以转化为对矩阵的行求最长下降子序列.
code:
#include<bits/stdc++.h>
using namespace std;
#define int long long
const int maxm=333;
int a[maxm][maxm];
int d[maxm];
int n,m;
int ok(int i,int j){//判断第i行是否严格小于第j行
for(int k=1;k<=m;k++){
if(a[i][k]>=a[j][k])return 0;
}
return 1;
}
signed main(){
ios::sync_with_stdio(0);cin.tie(0);
cin>>n>>m;
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
cin>>a[i][j];
}
}
int ans=0;
for(int i=1;i<=n;i++){
d[i]=1;
for(int j=1;j<i;j++){
if(ok(i,j)){
d[i]=max(d[i],d[j]+1);
}
}
ans=max(ans,d[i]);
}
cout<<n-ans<<endl;
return 0;
}