Atcoder Regular 097 相邻球交换目的递增DP
A
/*Huyyt*/
#include<bits/stdc++.h>
#define mem(a,b) memset(a,b,sizeof(a))
#define pb push_back
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
const ll LLmaxn = 2e18;
string a;
int K;
string str[];
int pop = ;
map<string, int> mp;
int main()
{
cin >> a;
cin >> K;
for (int i = ; i <= && pop < K; i++)
{
for (int j = ; j < a.size(); j++)
{
if (a[j] == 'a' + i)
{
string now = "";
for (int k = j; k < min((int)a.size(), j + K); k++)
{
now += a[k];
if (!mp[now])
{
str[++pop] = now;
//cout<<now<<endl;
mp[now]++;
}
}
}
}
}
sort(str + , str + pop + );
cout << str[K] << endl;
return ;
}
B
给1-N的一个排列 再给你M个Xi,Yi表示Xi与Yi位置的数可以无限次交换
解:
并查集 因为交换次数是无线的所以在一个集内的数字可以到其他任何一个位置
/*Huyyt*/
#include<bits/stdc++.h>
#define mem(a,b) memset(a,b,sizeof(a))
#define pb push_back
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
const ll LLmaxn = 2e18;
const int N = ;
int par[N];
void init(int n)
{
for (int i = ; i <= n; i++)
{
par[i] = i;
}
}
int find(int x)
{
return par[x] == x ? x : par[x] = find(par[x]);
}
void unite(int x, int y)
{
x = find(x);
y = find(y);
if (x != y)
{
par[x] = y;
}
}
int num[N];
int where[N];
int a, b;
int main()
{
int n;
int m;
cin >> n;
cin >> m;
init(n);
int anser = ;
for (int i = ; i <= n; i++)
{
cin >> num[i];
where[num[i]] = i;
}
for (int i = ; i <= m; i++)
{
cin >> a >> b;
unite(a,b);
}
for (int i = ; i <= n; i++)
{
if (find(where[i]) == find(i))
{
anser++;
}
}
cout << anser << endl;
return ;
}
C
有2N个球 一半是白的 一半是黑的 每个白球和黑球上都有一个数字 分别都可以组成1-N
在一次操作内你可以交换相邻的两个球 问你最少需要多少次操作使得从左到右 白球和黑球各自都是递增序
解:
dp[i][j]表示现在在(i+j)的位置有1-i白球且1-j黑球正确排序所需要的最少操作数
pre[kind][i][j]表示第kind种的球在第i个位置及之前标号不小于j的有几个
/*Huyyt*/
#include<bits/stdc++.h>
#define mem(a,b) memset(a,b,sizeof(a))
#define pb push_back
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
const ll LLmaxn = 2e18;
const int N = 2e3 + ;
int n;
int s;
int dp[N][N];
int pos[][N];
int pre[][N * ][N];
void init()
{
for (int kind = ; kind <= ; kind++)
{
for (int i = ; i < s; i++)
{
for (int j = n - ; j >= ; j--)
{
pre[kind][i][j - ] += pre[kind][i][j];
}
}
for (int i = ; i < s - ; i++)
{
for (int j = ; j < n; j++)
{
pre[kind][i + ][j] += pre[kind][i][j];
}
}
}
for (int i = ; i <= n; i++)
{
for (int j = ; j <= n; j++)
{
dp[i][j] = INT_MAX;
}
}
dp[][] = ;
}
int main()
{
cin >> n;
s = n * ;
for (int i = ; i < s; i++)
{
string ch;
cin >> ch;
int kind = ;
int x;
cin >> x;
x--;
if (ch[] == 'W')
{
kind = ;
}
pos[kind][x] = i;
pre[kind][i][x]++;
}
init();
for (int i = ; i <= n; i++)
{
for (int j = ; j <= n; j++)
{
if (i < n)
{
int p = pos[][i];
dp[i + ][j] = min(dp[i + ][j], dp[i][j] + pre[][p][i + ] + pre[][p][j]);
}
if (j < n)
{
int p = pos[][j];
dp[i][j + ] = min(dp[i][j + ], dp[i][j] + pre[][p][i] + pre[][p][j + ]);
}
}
}
cout << dp[n][n] << endl;
return ;
}
Atcoder Regular 097 相邻球交换目的递增DP的更多相关文章
- AtCoder Regular Contest 096 D - Static Sushi(线性dp)
Problem Statement "Teishi-zushi", a Japanese restaurant, is a plain restaurant with only o ...
- AtCoder Regular Contest 097
AtCoder Regular Contest 097 C - K-th Substring 题意: 求一个长度小于等于5000的字符串的第K小子串,相同子串算一个. K<=5. 分析: 一眼看 ...
- AtCoder Regular Contest 102
AtCoder Regular Contest 102 C - Triangular Relationship 题意: 给出n,k求有多少个不大于n的三元组,使其中两两数字的和都是k的倍数,数字可以重 ...
- AtCoder Regular Contest 061
AtCoder Regular Contest 061 C.Many Formulas 题意 给长度不超过\(10\)且由\(0\)到\(9\)数字组成的串S. 可以在两数字间放\(+\)号. 求所有 ...
- AtCoder Regular Contest 093
AtCoder Regular Contest 093 C - Traveling Plan 题意: 给定n个点,求出删去i号点时,按顺序从起点到一号点走到n号点最后回到起点所走的路程是多少. \(n ...
- AtCoder Regular Contest 094
AtCoder Regular Contest 094 C - Same Integers 题意: 给定\(a,b,c\)三个数,可以进行两个操作:1.把一个数+2:2.把任意两个数+1.求最少需要几 ...
- AtCoder Regular Contest 095
AtCoder Regular Contest 095 C - Many Medians 题意: 给出n个数,求出去掉第i个数之后所有数的中位数,保证n是偶数. \(n\le 200000\) 分析: ...
- AtCoder Regular Contest 099
AtCoder Regular Contest 099 C - Minimization 题意 题意:给出一个n的排列.每次操作可以使一段长度为K的连续子序列变成该序列的最小数.求最少几次使得整个数列 ...
- AtCoder Regular Contest 069 F Flags 二分,2-sat,线段树优化建图
AtCoder Regular Contest 069 F Flags 二分,2-sat,线段树优化建图 链接 AtCoder 大意 在数轴上放上n个点,点i可能的位置有\(x_i\)或者\(y_i\ ...
随机推荐
- 浏览器端-W3School-JavaScript:Screen 对象
ylbtech-浏览器端-W3School-JavaScript:Screen 对象 1.返回顶部 1. Screen 对象 Screen 对象 Screen 对象包含有关客户端显示屏幕的信息. 注释 ...
- BurpSuite(一)工具介绍
, 本章目标: 1. 安装并配置好Burpsuite 2. 了解其各个模块功能 Burpsuite介绍 Burp Suite 是用于攻击web应用程序的集成平台.它包含了许多工具,并为这些工具设计了许 ...
- Netflix颠覆HR:我们只雇“成年人”
员工的最佳福利,是与优秀者一起工作 ● Patty McCord / 文 李钊/译 担任Netflix的首席人才官时,我与CEO里德·黑斯廷斯一起做了一份127页的PPT,命名为<自由& ...
- centos7.5搭建svn
1.安装svnyum install subversion 2.查看安装位置rpm -ql subversion 3.创建svn版本库目录mkdir -p /var/svn/svnrepos 4.创建 ...
- python学习之函数(二)
4.4.6 动态传参 动态传参是针对形参而言 1.动态位置参数 在静态位置参数时,我们知道,定义函数时有几个位置参数,调用时就必须给几个实参,不能多也不能少.有时候,实际应用过程中,参数往往不能固 ...
- P3611 【[USACO17JAN]Cow Dance Show奶牛舞蹈】
想了一下还是不发以前做过的水题了,意义也不是很大,现在的话大概只有洛谷黄题以上才会收录了哦~~~ 喵了个咪的题面~~ 洛谷题解dalao不是P党就是优先队列,看的我作为一个新手蒟蒻好慌啊... 这题用 ...
- python基本成分详解
字符串 一.需要了解的 msg = 'HelloWorld' 1.isdecimal判断是否是十进制(整数)w print(msg.isdecimal()) 2.endswith判断字符串末尾是否是指 ...
- 配置java开发环境,存在多个版本JDK时,怎样让所需版本生效
我本地有个1.7.0的java版本,后来我新装了一个13的版本,但是命令行查java版本的时候,生效的还是1.7.0的版本,经过资料查询以及自身亲测,现将过程记录如下: 1.电脑右键选择--属性--高 ...
- python中的生成器、迭代器、闭包、装饰器
迭代器 迭代是访问集合元素的一种方式.迭代器是一个可以记住遍历的位置的对象.迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束.迭代器只能往前不会后退. 可迭代对象 以直接作用于 for ...
- java.lang.ClassNotFoundException: org.springframework.web.filter.CharacterEncodingFilter的解决方案
白天在实验室的电脑上的项目搭起来,晚上回到宿舍发现跑不起来了,网上查到的大多不是想要的答案. 最终的解决方案是maven clean一下再重新package.