[Codeforces #615 div3]1294E Obtain a Permutation
Before the Beginniing
本文为 Clouder 原创文章,原文链接为Click,转载时请将本段放在文章开头显眼处。如进行了二次创作,请明确标明。
由本人转载于博客园。
题意分析
Codeforces题目链接
给出一个 \(n \times m\) 的矩阵,给出两种操作:
- 将某一列整体向上移动一位。
- 修改某一个位置的值。
求最少要多少次操作,使得矩阵成为如下形式:

思路
很容易发现,每一列的操作都是独立的。
那么就一列列处理即可。
问题转化为如何求一列变为目标形式的最少操作次数。
而修改和平移是不冲突的,可以直接考虑先平移再修改。
暴力枚举法
于是得到一个很直观的思路,枚举向上移动多少次,再检查每一个数计算要修改多少次达到目标状态。
这样每列的复杂度是 \(O(n^2)\) 的,总复杂度显然不可接受。
计算位置法
考虑每列要修改多少次受什么影响。
在向上平移特定距离之后,如果平移后有位置刚好对应上,则不需要修改。
每个位置数确定之后,其能对应的位置也确定了,可以直接计算出在平移几格时的情况该位置不需要修改。
比如图中第一列,第二行如果有一个数 \(1\),可以直接通过计算得出其应当在的位置为第一行,于是在平移一格时的情况它不用修改,记录下来即可。
那么整体把矩阵扫一遍处理即可,时间复杂度 \(O(nm)\),可以通过。
解法
还是有一些细节的。
首先不能直接开 \(nm\) 大小的数组,会爆空间,这里使用了 vector 来处理。
而 \(s[i]\) 代表的是 向上平移 \(i\) 格时有多少个位置不需要修改。
那么操作步数可以通过平移格数和修改数计算出。
这里的数组 \(s\) 直接滚动优化掉一维,注意使用循环清空,就不会清空不使用的部分,而用 memset 会超时。
计算新位置建议自己画图手推一下,代个例子进去。
由于使用 vector,下标从 \(0\) 开始了,按个人习惯来吧。
代码
#include <cstdio>
#include <vector>
using namespace std;
inline int read()
{
static char c;
int r = 0;
for (c = getchar(); c > '9' || c < '0'; c = getchar());
for (; c >= '0' && c <= '9'; r = (r << 1) + (r << 3) + (c ^ 48), c = getchar());
return r;
}
const int maxn = 2e5 + 100;
int n, m;
vector<int> a[maxn];
int s[maxn];
int ans;
int main()
{
n = read();
m = read();
for (int i = 0; i < n; ++i)
for (int j = 0; j < m; ++j)
a[i].push_back(read());
int maxx = n * m;
for (int j = 0; j < m; ++j)
{
for (int i = 0; i < n; ++i)
s[i] = 0;
for (int i = 0; i < n; ++i)
{
if (a[i][j] > maxx || a[i][j] < j || ((a[i][j] - j - 1) % m) != 0)
continue;
int p = (a[i][j] - j - 1) / m;
if (i >= p)
s[i - p]++;
else
s[i + n - p]++;
}
int res = 1 << 30;
for (int i = 0; i < n; ++i)
if (n - s[i] + i < res)
res = n - s[i] + i;
ans += res;
}
printf("%d\n", ans);
return 0;
}
[Codeforces #615 div3]1294E Obtain a Permutation的更多相关文章
- Codeforces 1294E - Obtain a Permutation
题目大意: 给定一个n*m的矩阵 可以更改任意一个位置的值 也可以选择一整列全部往上移动一位,最上方的数移动到最下方 问最少操作多少次可以把这个矩阵移动成 1 2 3 ... m m+1 m+2 m+ ...
- Codeforces #550 (Div3) - G.Two Merged Sequences(dp / 贪心)
Problem Codeforces #550 (Div3) - G.Two Merged Sequences Time Limit: 2000 mSec Problem Description T ...
- Codeforces 1091D New Year and the Permutation Concatenation 找规律,数学 B
Codeforces 1091D New Year and the Permutation Concatenation https://codeforces.com/contest/1091/prob ...
- codeforces 615 D. Multipliers (数论 + 小费马定理 + 素数)
题目链接: codeforces 615 D. Multipliers 题目描述: 给出n个素数,这n个素数的乘积等于s,问p的所有因子相乘等于多少? 解题思路: 需要求出每一个素数的贡献值,设定在这 ...
- codeforces 615 B. Longtail Hedgehog (DFS + 剪枝)
题目链接: codeforces 615 B. Longtail Hedgehog (DFS + 剪枝) 题目描述: 给定n个点m条无向边的图,设一条节点递增的链末尾节点为u,链上点的个数为P,则该链 ...
- codeforces #579(div3)
codeforces #579(div3) A. Circle of Students 题意: 给定一个n个学生的编号,学生编号1~n,如果他们能够在不改变顺序的情况下按编号(无论是正序还是逆序,但不 ...
- U - Obtain a Permutation CodeForces - 1294E 思维
题解: 注意每一列与每一列之间互不影响,所以贪心地求出没一列的最小操作值,然后累加起来. 怎么求没一列的最小值呢?维护一个数组same表示其中same[i]=j表示将该序列向上翻滚i次有j个元素归位, ...
- Twist the Permutation 数列的轮换题 Codeforces 776 div3
这是一道比较经典的将数列中的数字轮换的题目,我们先看题干: 题干分析:先浅浅地分析一下题目是要我们干什么,我们会默认有一个已经升序排序地1~n的排列,然后我们会给定一个新排列是在原有排列的基础上进行o ...
- Educational Codeforces Round 7 D. Optimal Number Permutation 构造题
D. Optimal Number Permutation 题目连接: http://www.codeforces.com/contest/622/problem/D Description You ...
随机推荐
- (2)Linux Java环境变量安装
install default JRE/JDK Installing Java with apt-get is easy. First, update the package index: sudo ...
- WinForm开发(4)——使用Visual-Studio-2010-打包安装程序
打包程序: 1,解决方案—右键菜单“添加”—新建项目—其他项目类型—安装和部署—Visual Studio Installer—安装项目,输入名称Setup1,点“确定” 2,添加开始程序中的文件夹: ...
- 201771010135杨蓉庆 《面对对象程序设计(java)》第八周学习总结
1.实验目的与要求 (1) 掌握接口定义方法: (2) 掌握实现接口类的定义要求: (3) 掌握实现了接口类的使用要求: (4) 掌握程序回调设计模式: (5) 掌握Comparator接口用法: ( ...
- IoT协议LwM2M MQTT与CoAP
IoT协议LwM2M MQTT与CoAP 一.MQTT 1.概述: MQTT(Message Queuing Telemetry Transport,消息队列遥测传输)是IBM开发的一个即时通讯协议, ...
- 常见排序的Java实现
插入排序 1.原理:在有序数组中从后向前扫描找到要插入元素的位置,将元素插入进去. 2.步骤:插入元素和依次和前一个元素进行比较,若比前一个元素小就交换位置,否则结束循环. 3.代码: package ...
- js指定范围指定个数的不重复随机数
今天偶然看到的 比如要生成 1-100范围之内的10个不重复随机数,代码就可以这么写 var arr = []; for (var i = 1; i <=100; i++) { arr.push ...
- 研发2nm芯片,台积电如何做到天下第一?
日前,台积电宣布,正式启动2nm芯片工艺的研发,工厂将会设置在台湾新竹的南方科技园,预计2024年投入量产,发言人称:2nm工艺是一个重要节点,目标是比3nm制程缩小23%.科技先锋总会打脸分析专家, ...
- PAT T1004 To Buy or Not to Buy - Hard Version
暴力搜索加剪枝~ #include<bits/stdc++.h> using namespace std; ; string t; string s[maxn]; int pos[maxn ...
- MySQL(window10)加载配置文件的顺序
mysql加载配置的顺序为:(mysql --help中有详细的说明) C:\WINDOWS\my.ini C:\WINDOWS\my.cnf C:\my.ini C:\my.cnf D:***\my ...
- Css——设置input输入框光标颜色
在使用 input 输入框时,我们可能会遇到需要给其设置光标颜色的情况.谷歌浏览器的默认光标颜色是黑色的,GitHub 上的光标却是白色,那么这个用 CSS 怎么改变呢? 上面描述的情景有两种实现方式 ...