码迷,mamicode.com
首页 > 其他好文 > 详细

Obtain a Permutation 乱搞

时间:2020-01-24 20:09:48      阅读:84      评论:0      收藏:0      [点我收藏+]

标签:img   for   元素   --   scan   onclick   play   class   clu   

 

题意:

给定一个矩阵,问最少能用多少次操作使得矩阵有序(类似离散化坐标)

操作一: 修改一个元素的值

操作二:将矩阵的一列上移

 

技术图片
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const ll mod=1e9+7;
const int N=1e6+100;

map<int,int>mp;

int main() {
    int n,m;
    cin>>n>>m;
    int a[2*n+1][m+1];
    for(int i=1;i<=n;i++)
        for(int j=1;j<=m;j++)
            scanf("%d",&a[i][j]),a[i+n][j]=a[i][j];
    int ans=0;

    for(int temp,j=1;j<=m;j++,ans+=temp) {
        temp=n;
        mp.clear();
        for(int i=1;i<=2*n;i++) a[i][j]-=(i-1)*m;
        for(int i=1;i<=n;i++) mp[a[i][j]]++;
        for(int i=1;i<=n;i++) {
            temp=min(temp,i-1+n-mp[j-(i-1)*m]);
            --mp[a[i][j]];
            ++mp[a[i+n][j]];
        }
    }
    cout<<ans;
}
View Code

 

Obtain a Permutation 乱搞

标签:img   for   元素   --   scan   onclick   play   class   clu   

原文地址:https://www.cnblogs.com/bxd123/p/12232500.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!