bestcoder round 74 div2
随便看了一场以前的bestcoder,然后顺便写了一下,都不码的样子
有中文题面,这里就不写题目大意了
T1.
刚开始想复杂了,T1可能是4道题里面想的最久的
我们大概弄一下就可以发现,如果a[i]>0,并且a[i+1]满足条件,那么s[i]=s[i+1]
所以我们发现其实是一堆相同的弄在一起。
当然如果a[i]=0那么说明s[i]!=s[i-1],这样i就有25种选法,刚开始有26种选法
就是ans=26*25^(a[i]==0的个数)
我们考虑什么时候答案=0,显然a[i]!=0&&a[i]!=a[i+1]+1那么就不合法了
代码:
#include<bits/stdc++.h>
#define N 2000005
#define Mod 1000000007
using namespace std;
int n,T,ans,a[N];
int main(){
scanf("%d",&T);
while (T--){
scanf("%d",&n);n--;ans=26;
for (int i=1;i<=n;i++) scanf("%d",&a[i]);a[n+1]=0;
for (int i=1;i<=n;i++)
if (a[i]!=a[i+1]+1&&a[i]!=0) ans=0;
for (int i=1;i<=n;i++)
if (!a[i]) ans=1ll*ans*25%Mod;
printf("%d\n",ans);
}
return 0;
}
T2.
因为只有3条边,显然不会重复走,最短路一定是正常走+走加入的三条路
那么只要枚举一下3条路的排列,然后方向判断一下,dfs就ok了
代码:
#include<bits/stdc++.h>
#define N 500005
#define Mod 1000000007
using namespace std;
int T,n,m,a[N],b[N],s,t,ans,sum;bool use[5];
void dfs(int now,int tot){
if (tot+abs(now-t)<ans) ans=tot+abs(now-t);
for (int i=1;i<=3;i++){
if (use[i]) continue;
use[i]=1;
dfs(a[i],tot+1+abs(now-b[i]));
dfs(b[i],tot+1+abs(now-a[i]));
use[i]=0;
}
}
int main(){
scanf("%d",&T);
while (T--){
scanf("%d%d",&n,&m);
for (int i=1;i<=3;i++) scanf("%d%d",&a[i],&b[i]);
for (int i=1;i<=m;i++){
ans=1e9;scanf("%d%d",&s,&t);
dfs(s,0);
sum=(sum+1ll*i*ans%Mod)%Mod;
}
printf("%d\n",sum);sum=0;
}
return 0;
}
T3.
对于第一个操作,其实等价于xor一个2^x
其实原问题等价于求0-->S^T的最少操作次数
我们发现n<=15,所以我们对于a[i]暴力dfs求出用这些数组成的数的最小次数
dp[i]表示构成i的最小次数
然后考虑操作1
因为都是xor一个2的次方数,所以每一位都是相互独立的
如果x^3是最优的,那么x^1一定是最优的,然后x^1^2也随之一定是最优的
所以我们把x从0到15枚举一下
然后再枚举i的值,更新一下dp值即可
一般的位运算的题,都是先枚举次方再枚举i的
代码:
#include<bits/stdc++.h>
#define N 1000005
#define Mod 1000000007
using namespace std;
int T,n,m,s,t,ans,a[N],mp[N];
void dfs(int u,int dep,int sum){
if (mp[sum]>dep) mp[sum]=dep;
if (u==n+1) return;
dfs(u+1,dep+1,sum^a[u]);
dfs(u+1,dep,sum);
}
int main(){
scanf("%d",&T);
while (T--){
scanf("%d%d",&n,&m);
memset(mp,127,sizeof(mp));
for (int i=1;i<=n;i++) scanf("%d",&a[i]);
dfs(1,0,0);
for (int j=0;j<=17;j++)
for (int i=0;i<=(1<<18);i++)
if (mp[i^(1<<j)]>mp[i]+1) mp[i^(1<<j)]=mp[i]+1;
for (int i=1;i<=m;i++){
scanf("%d%d",&s,&t);
//cerr<<mp[s^t]<<endl;
ans=(ans+1ll*mp[s^t]*i%Mod)%Mod;
}
printf("%d\n",ans);ans=0;
}
return 0;
}
T4.
感觉T2-T4都没啥难度,还是T1最难(┭┮﹏┭┮)<----弱
显然的贪心,如果当前剩下的点中最小的点能够通过删边来得到,那么就删那个条数
注意我们不用考虑删的是哪些边
因为这个点拓扑了,那么意味着从它出发的边都要删除,所以不用知道具体哪些,只要知道这个点是不是要删即可
然后用一个堆来维护一下点的大小值即可
代码:
#include<bits/stdc++.h>
#define N 2000005
#define Mod 1000000007
using namespace std;
int n,m,k,T,x,y,kk,head[N],ru[N];bool use[N],flag[N];
struct Edge{int nxt,to;}e[N];
priority_queue<int,vector<int>,greater<int> > Q;
inline void link(int x,int y){e[++kk].nxt=head[x];e[kk].to=y;head[x]=kk;}
int main(){
scanf("%d",&T);
while (T--){
scanf("%d%d%d",&n,&m,&k);
memset(ru,0,sizeof(ru));
kk=0;memset(head,0,sizeof(head));
while (!Q.empty()) Q.pop();
for (int i=1;i<=m;i++){
scanf("%d%d",&x,&y);
link(x,y);ru[y]++;
}
for (int i=1;i<=n;i++){
if (ru[i]<=k) Q.push(i),flag[i]=0;
else flag[i]=1;
}
long long ans=0,tot=0;
while (!Q.empty()){
while (ru[Q.top()]>k){flag[Q.top()]=1;Q.pop();}
int x=Q.top();int y=ru[x];
//printf("WTF%d\n",x);
ru[x]=0;k-=y;
Q.pop();ans=(ans+1ll*(++tot)*x%Mod)%Mod;
for (int i=head[x];i;i=e[i].nxt){
int v=e[i].to;
if (ru[v]<=k+1&&ru[v]>0&&flag[v]){flag[v]=0;Q.push(v);}
ru[v]--;
}
}
printf("%lld\n",ans);
}
return 0;
}
bestcoder round 74 div2的更多相关文章
- hdu5635 BestCoder Round #74 (div.2)
LCP Array Accepts: 131 Submissions: 1352 Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 13 ...
- hdu 5636 搜索 BestCoder Round #74 (div.2)
Shortest Path Accepts: 40 Submissions: 610 Time Limit: 4000/2000 MS (Java/Others) Memory Limit: ...
- BestCoder Round #74 (div.2)
组合 1001 LCP Array 第一题就小难,出题的好像是浙大的大牛? 找到一个规律:a[i] = x, s[i..i+x]都想同.a[i] = a[i+1] + 1 (a[i] > 0), ...
- BestCoder Round #74
身败名裂啊...... T1WA了半天,30min才A. T2又WA了一发,然后Hack刚2min就被别人叉了. T3做完后最后40min不知所措. 去叉别人,看到一个人写D题判m=0很奇怪,随手把他 ...
- hdu 5637 BestCoder Round #74 (div.2)
Transform Accepts: 7 Submissions: 49 Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 131072 ...
- BestCoder Round #74 (div.1) 1002Shortest Path(hdoj5636)
哈哈哈哈,我就知道这道题目再扔给我,我还是不会,就是这么菜,哈哈哈 一开始官方题解就没搞懂-然后就看了一下别人的代码,水水过就算了.今天拿到-GG: 题意: 一开始,有一张原图,有一条长度为n的链. ...
- HDU5638 / BestCoder Round #74 (div.1) 1003 Toposort 线段树+拓扑排序
Toposort 问题描述 给出nn个点mm条边的有向无环图. 要求删掉恰好kk条边使得字典序最小的拓扑序列尽可能小. 输入描述 输入包含多组数据. 第一行有一个整数TT, 表示测试数据组数. 对 ...
- Bestcoder round #65 && hdu 5592 ZYB's Premutation 线段树
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)Total Submissio ...
- hdu5634 BestCoder Round #73 (div.1)
Rikka with Phi Accepts: 5 Submissions: 66 Time Limit: 16000/8000 MS (Java/Others) Memory Limit: ...
随机推荐
- std::cout和printf
禁止std::cout和printf混用,在多线程环境下可能导致coredump. 说明:printf和std::cout分别为标准c语言与c++中的函数,两者的缓冲区机制不同(printf无缓冲区, ...
- python 多窗口编辑
同时打开多个文件: 1,vim filename1 filename2 在打开的多个文件中 :next 转到下个文件中 :prev 转到上个文件中 :last/:first 分别到最后一个和第一个文件 ...
- Linux0.11小结
第一部分 基础内容 1.操作系统基础 操作系统是计算机硬件系统与用户程序间重要环节,理解操作系统的原理是编写优秀代码的基础.教课书中阐述的操作系统一般由5部分组成. 一个最简单的操作系统,可以 ...
- Eclipse搭建Android环境失败的解决方案
今天在Eclipse上搭建Android开发环境,不仅在安装ADT的过程中老是出错,而且Android SDK下载后,打开SDK Manager时也无法链接到网页下载tools,网上查了好多方法,试了 ...
- Win8 HTML5与JS编程学习笔记(一)
微软的Visual Studio提供了多种构成win8应用的方式,其中最让我感到激动的是基于网页设计语言的开发模式,它提供了结合HTML5与Javascript来开发应用的方法,通过这种方法进行开发, ...
- 增量会话对象——DeltaSession
在集群环境中为了使集群中各个节点的会话状态都同步,同步操作是集群重点解决的问题,一般来说有两种同步策略,其一是每次同步都把整个会话对象传给集群中其他节点,其他节点更新整个会话对象:其二是对会话中增量修 ...
- Android Camera开发系列(下)——自定义Camera实现拍照查看图片等功能
Android Camera开发系列(下)--自定义Camera实现拍照查看图片等功能 Android Camera开发系列(上)--Camera的基本调用与实现拍照功能以及获取拍照图片加载大图片 上 ...
- obj-c编程15[Cocoa实例02]:KVC和KVO的实际运用
我们在第16和第17篇中分别介绍了obj-c的KVC与KVO特性,当时举的例子比较fun,太抽象,貌似和实际不沾边哦.那么下面我们就用一个实际中的例子来看看KVC与KVO是如何运用的吧. 该例中用到了 ...
- 恶补web之六:javascript知识(2)
若要向html添加新元素,必须首先创建该元素,然后向一个已存在的元素追加该元素 <div id="div1"> <p id="p1">这 ...
- git对远程分支和tag的操作
技术 Git查看.删除.重命名远程分支和tag 11/17/2012zrong7条评论69,235 次查看 本站文章除注明转载外,均为本站原创或者翻译. 本站文章欢迎各种形式的转载,但请18岁以上的转 ...