2018 Multi-University Training Contest 2 杭电多校第二场
开始逐渐习惯被多校虐orz 菜是原罪
1004 Game (hdoj 6312)
链接:http://acm.hdu.edu.cn/showproblem.php?pid=6312
虽然披着博弈的外壳 但是也算是结论题 一开始开题的时候一看到博弈就不想写了 但是大佬们过题太快了 所以想到可能是结论题
题意:有A和B两个人可以对一个1-n的全排列进行操作 每一次都可以删去一个数和它所有质子 A和B轮流进行操作 先删光全排列为赢 A先手 给出n 判断A的输赢
因为每一次删数操作都会删去1 所以可以忽视掉1 直接看2-n的状态 如果在这个状态下B赢了 那么A先去选择1来转变自己的局面 A可以赢 如果2-n的状态下A赢了 可以不用专门去选择1 保持赢的状态 所以A是必胜的
知道这个结论后 代码就无比的简单了 不过要注意多组输入 这一场都要注意这个问题
代码如下
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int main(){
int n;
while(scanf("%d",&n)!=EOF){
printf("Yes\n");
}
return ;
}
1007 Naive Operations (hdoj 6315)
链接:http://acm.hdu.edu.cn/showproblem.php?pid=6315
需要优化的线段树
题意:给一个全排列的数组b和为空的数组a 分为两个操作 第一个操作为给指定区间l-r a[l]-a[r]都加上1 第二个操作为给定指定区间 求b[l]/a[i]到b[r]/a[r]的和
区间求和问题 一开始想到的是裸的树状数组 但是太暴力 华丽丽的给卡掉了 一直卡到了比赛结束
每次对a数组进行++操作 都转化成--操作 具体做法为设一个minn赋值为对应的b[i]的值 一旦a[i]++,可以转换为minn--,直到minn为零 此时用于计数的sum进行++,minn重新赋值为b[i]
代码如下
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
typedef long long ll;
const int maxn=1e5+;
struct node{
ll sum,pos,minn,lazy;
}kk[maxn<<];
int a[maxn];
void pushup(int rt){
kk[rt].minn=min(kk[rt<<].minn,kk[rt<<|].minn);
kk[rt].sum=kk[rt<<].sum+kk[rt<<|].sum;
}
void pushdown(int rt){
if(kk[rt].lazy){
kk[rt<<].lazy+=kk[rt].lazy;
kk[rt<<|].lazy+=kk[rt].lazy;
kk[rt<<].minn-=kk[rt].lazy;
kk[rt<<|].minn-=kk[rt].lazy;
kk[rt].lazy=;
}
}
void build(int l,int r,int rt){
kk[rt].lazy=kk[rt].sum=;
if(l==r){
kk[rt].minn=kk[rt].pos=a[l];
kk[rt].sum=;
return ;
}
int mid=(l+r)>>;
build(l,mid,rt<<);
build(mid+,r,rt<<|);
pushup(rt);
}
void update(int L,int R,int l,int r,int rt){
if(L<=l&&r<=R&&kk[rt].minn>){
kk[rt].lazy++;
kk[rt].minn--;
return ;
}
if(l==r&&kk[rt].minn==){
kk[rt].sum++;
kk[rt].minn=kk[rt].pos;
kk[rt].lazy=;
return ;
}
int mid=(l+r)>>;
pushdown(rt);
if(L<=mid) update(L,R,l,mid,rt<<);
if(R>mid) update(L,R,mid+,r,rt<<|);
pushup(rt);
}
ll query(int L,int R,int l,int r,int rt){
if(L<=l&&r<=R) return kk[rt].sum;
int mid=(l+r)>>;
pushdown(rt);
ll ans=;
if(L<=mid) ans+=query(L,R,l,mid,rt<<);
if(R>mid) ans+=query(L,R,mid+,r,rt<<|);
return ans;
}
int main(){
int n,q,l,r;
while(~scanf("%d%d",&n,&q)){
for(int i=;i<=n;i++) scanf("%d",&a[i]);
build(,n,);
while(q--){
char s[];
scanf("%s%d%d",s,&l,&r);
if(s[]=='a') update(l,r,,n,);
if(s[]=='q') printf("%lld\n",query(l,r,,n,));
}
}
return ;
}
1011 Swaps and Inversions (hdoj 6318)
链接:http://acm.hdu.edu.cn/showproblem.php?pid=6318
树状数组+离散化 求逆序数
题意:给出一个数列 如果一个数的逆序数不为0 则要付出逆序数*x的代价 但是也可以选择交换相邻两项来减少逆序数 每次交换需要付出的代价为y
只要想到这是逆序数 就是一题板子题了 因为相邻两项也可以构成逆序对 所以就可以把问题简化为逆序数和*min(x,y)
逆序数在线性代数中有定义(orz还好没忘记这学期刚学的线代)一个数的逆序数 是在这个数之后所有比它要小的数字个数的和 这里可以用离散化的思想来处理 用树状数组来进行修改和查询
有个小坑 一直wa 后知后觉发现是姿势不对orz 在排序的时候进行特判 差不多一个结构体二重排序(?)
哦对了 会爆int 要开long long
代码如下:
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
using namespace std;
const int maxn=1e5+;
typedef long long ll;
int c[maxn],pos[maxn];
int n;
struct node{
int v;
int id;
}kk[maxn];
int cmp(node a,node b){
if(a.v==b.v) return a.id<b.id;
else return a.v<b.v;
}
int lowbit(int x){
return x&(-x);
}
void insert(int i,int x){
while(i<=n){
c[i]+=x;
i+=lowbit(i);
}
}
ll getsum(int i){
ll sum=;
while(i>=){
sum+=c[i];
i-=lowbit(i);
}
return sum;
}
int main(){
int x,y;
while(~scanf("%d%d%d",&n,&x,&y)){
ll ans=;
for(int i=;i<=n;i++){
scanf("%d",&kk[i].v);
kk[i].id=i;
}
sort(kk+,kk+n+,cmp);
for(int i=;i<=n;i++){
pos[kk[i].id]=i;
}
memset(c,,sizeof(c));
for(int i=;i<=n;i++){
insert(pos[i],);
ans+=i-getsum(pos[i]);
}
printf("%lld\n",(ll)ans*min(x,y));
}
return ;
}
2018 Multi-University Training Contest 2 杭电多校第二场的更多相关文章
- 2018 Multi-University Training Contest 1 杭电多校第一场
抱着可能杭电的多校1比牛客的多校1更恐怖的想法 看到三道签到题 幸福的都快哭出来了好吗 1001 Maximum Multiple(hdoj 6298) 链接:http://acm.hdu.edu. ...
- 2018 Multi-University Training Contest 9 杭电多校第九场 (有坑待补)
咕咕咕了太久 多校博客直接从第三场跳到了第九场orz 见谅见谅(会补的!) 明明最后看下来是dp场 但是硬生生被我们做成了组合数专场…… 听说jls把我们用组合数做的题都用dp来了遍 这里只放了用组 ...
- hdu6312 2018杭电多校第二场 1004 D Game 博弈
Game Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submis ...
- 杭电多校第二场 hdu 6315 Naive Operations 线段树变形
Naive Operations Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 502768/502768 K (Java/Other ...
- 2018 Multi-University Training Contest 3 杭电多校第三场
躺了几天 终于记得来填坑了 1001 Ascending Rating (hdoj 6319) 链接:http://acm.hdu.edu.cn/showproblem.php?pid=6319 ...
- 2018杭电多校第二场1003(DFS,欧拉回路)
#include<bits/stdc++.h>using namespace std;int n,m;int x,y;int num,cnt;int degree[100007],vis[ ...
- 2019杭电多校第二场hdu6601 Keen On Everything But Triangle
Keen On Everything But Triangle 题目传送门 解题思路 利用主席树求区间第k小,先求区间内最大的值,再求第二大,第三大--直到找到连续的三个数可以构成一个三角形.因为对于 ...
- 2019杭电多校第二场hdu6602 Longest Subarray(线段树)
Longest Subarray 题目传送门 解题思路 本题求一个最大的子区间,满足区间内的数字要么出现次数大于等于k次,要么没出现过.给定区间内的数字范围是1~c. 如果r为右边界,对于一种数字x, ...
- 杭电多校第二场 1005 hack it
题意: 构造一个n*n 的 01 矩阵, 0 < n < 2001, 矩阵需要满足没有一个子矩阵的4个角都是1,并且矩阵内1的个数至少有85000个. 题解:数论构造题 参考From 代 ...
随机推荐
- python德国信用评分卡建模(附代码AAA推荐)
欢迎关注博主主页,学习python视频资源,还有大量免费python经典文章 python信用评分卡建模视频系列教程(附代码) 博主录制 https://study.163.com/course/i ...
- java io系列11之 FilterOutputStream
FilterOutputStream 介绍 FilterOutputStream 的作用是用来“封装其它的输出流,并为它们提供额外的功能”.它主要包括BufferedOutputStream, Dat ...
- Linux学习笔记:【000】Linux系统入门
什么是Linux? Linux是一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX(可移植操作系统接口 Portable Operating System Interface of UN ...
- STM32学习笔记:【004】USART串口通信
版本:STM32F429 Hal库v1.10 串口通信能够实现两块电路之间不同的通信,在开发中作为打印调试也是一门利器(printf重定向). 补充一点小知识: 1. weak修饰符修饰的函数,说明这 ...
- sc (service control )
SC 是用来与服务控制管理器和服务进行通信 net: net start 服务名 net stop 服务名 sc: sc config 服务名 start= demand //手动 sc con ...
- 细说log4j之log4j 1.x
官网:http://logging.apache.org/log4j/1.2/manual.html 三大组件:loggers,appenders,layouts. LoggersLogger是一个层 ...
- ueditor 百度编辑器图片上传 接 node.js 及一些前端自定义
百度编辑器 用node.js 做服务端 demo 大神已整理的 记录一下 以作参考 https://github.com/netpi/ueditor 1. 前端图片工具栏上传input file在这里 ...
- 持续集成CI相关的几个概念
持续集成 https://en.wikipedia.org/wiki/Continuous_integration 为什么要持续? 持续集成, 可以避免集成地狱(由于工作的源码 和 库中的源码的差异导 ...
- Javaweb学习笔记——(十三)——————JSTL、JSTL核心标签库、自定义标签、有标签体的标签、带有属性的标签、MVC、Javaweb三层框架
JSTLApache提供的标签库 jar包:jstl-1.2.jar,如果传MyEclipse,他会在我们导入jar包,无需自己导入,如果没有使用MyEclipse那么需要自行导入.--------- ...
- PDO和MySQLi区别与选择?
当用PHP访问数据库时,除了PHP自带的数据库驱动,我们一般还有两种比较好的选择:PDO和MySQLi.在实际开发过程中要决定选择哪一种首先要对二者有一个比较全面的了解.本文就针对他们的不同点进行分析 ...