【Nowcoder】玩游戏
Solution
所以说这是一道==纯粹的人类智慧题是这样吗qwq
一开始的时候想sg函数qwq然后发现。。好像根本不能拆成独立的子游戏嘛qwq
换一个角度来思考:首先考虑一下这个图的性质
因为这是一个简单无向图,然后除了起点和终点以外没有度数\(>2\)的点,也就是说不可能出现走到一个点之后出现分叉路这样的情况,更加具体一点就是:这个图中从\(1\)到\(n\)的路径都是互不相交的
注意到因为每次操作都是\(-1\),所以不管怎么操作一定能够得到一个这样的局面:只剩下一条从\(1\)到\(n\)的路径,并且这条路径上的每条边的边权都是\(1\),因为必须要进行一次操作,所以碰上这种局面的那个人必败
这个时候我们就可以得到一个比较直接的策略了:两个人都要尽可能地避免自己碰上种局面(为了方便表述,后面将这种只剩一条全\(1\)路的局面称为“结束局面”),也就是说,要尽早将自己会遇上的可能成为这种局面的\(1\)到\(n\)的路径断掉,断掉一条\(1\)到\(n\) 路径的最少操作次数为这条路径上的边权最小值,所以我们要做的就是,找出每条从\(1\)到\(n\)的路径,判断如果最后剩下的那条全是\(1\)的路是这条的话,会是谁要进行操作(也就是判断这条路径对谁来说必败),然后将断掉这条路径所需的的最少次数加到对应的那个人的统计变量中,最后只要判断一下两个统计变量的大小,就可以知道是谁先破坏完自己的必败路径了(也就是对方的必胜路径),先破坏完的那个人就是有必胜策略的
最后的问题就是如何判断一条路径对谁来说必败:注意到一个比较明显但是又很容易忽略的性质(比如说我就忽略了==),因为每次操作的时候都是\(-1\),所以先手操作完之后剩余边权之和与原边权和的奇偶性是不同的,后手操作完之后则一定是相同的,如果说一条路径是“结束局面”中剩的那条路径,那么这条路径包含的边的数量就是该局面的边权之和(因为根据定义结束局面中所有的边权都是\(1\)),所以我们可以直接通过这个以及一开始还没有进行任何操作时总的边权和的奇偶性来判断,如果奇偶性相同说明会是后手碰上,否则是先手碰上
然后因为这题对图的约束,边数什么的不会很多,\(1\)到\(n\)的路径总数也不会很多,所以我们直接爆搜一下统计一下就好了
mark:尝试从奇偶性的角度分析问题的时候。。不妨想一下剩余局面,比如说这题就是:先手操作完之后剩余边权之和与原边权和的奇偶性是不同的,后手操作完之后则一定是相同的
代码大概长这个样子
#include<iostream>
#include<cstdio>
#include<cstring>
#define ll long long
using namespace std;
const int N=1e5+10,inf=2147483647;
struct xxx{
int y,nxt,dis;
}a[N*2];
int h[N];
ll cnt[2];
int n,m,tot;
ll sum;
void add(int x,int y,int d){a[++tot].y=y; a[tot].nxt=h[x]; h[x]=tot; a[tot].dis=d;}
void dfs(int pre,int x,int who,int mn){
int u;
if (x==n){
cnt[who]+=mn; return;
}
for (int i=h[x];i!=-1;i=a[i].nxt){
u=a[i].y;
if (i==(pre^1)) continue;
dfs(i,u,who^1,min(mn,a[i].dis));
}
}
int main(){
#ifndef ONLINE_JUDGE
freopen("a.in","r",stdin);
#endif
int x,y,z;
scanf("%d%d",&n,&m);
memset(h,-1,sizeof(h));
tot=1; sum=0;
for (int i=1;i<=m;++i){
scanf("%d%d%d",&x,&y,&z);
add(x,y,z);
add(y,x,z);
sum+=z;
}
dfs(0,1,0,inf);
--sum;
if (cnt[sum&1]>cnt[sum&1^1]) printf("Yes\n");
else printf("No\n");
}
【Nowcoder】玩游戏的更多相关文章
- 牛客练习赛46 C 华华跟奕奕玩游戏 (期望,概率)(详解)
链接:https://ac.nowcoder.com/acm/contest/894/C 来源:牛客网 华华跟奕奕玩游戏 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 524288K ...
- 原生JS实战:写了个一边玩游戏,一边记JS的API的游戏
本文是苏福的原创文章,转载请注明出处:苏福CNblog:http://www.cnblogs.com/susufufu/p/5878913.html 本程序[一边玩游戏,一边记JS的API]是本人的个 ...
- bzoj4730: Alice和Bob又在玩游戏
Description Alice和Bob在玩游戏.有n个节点,m条边(0<=m<=n-1),构成若干棵有根树,每棵树的根节点是该连通块内编号最 小的点.Alice和Bob轮流操作,每回合 ...
- 小易邀请你玩一个数字游戏,小易给你一系列的整数。你们俩使用这些整数玩游戏。每次小易会任意说一个数字出来,然后你需要从这一系列数字中选取一部分出来让它们的和等于小易所说的数字。 例如: 如果{2,1,2,7}是你有的一系列数,小易说的数字是11.你可以得到方案2+2+7 = 11.如果顽皮的小易想坑你,他说的数字是6,那么你没有办法拼凑出和为6 现在小易给你n个数,让你找出无法从n个数中选取部分求和
小易邀请你玩一个数字游戏,小易给你一系列的整数.你们俩使用这些整数玩游戏.每次小易会任意说一个数字出来,然后你需要从这一系列数字中选取一部分出来让它们的和等于小易所说的数字. 例如: 如果{2,1,2 ...
- cdoj 1136 邱老师玩游戏 树形背包
邱老师玩游戏 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.uestc.edu.cn/#/problem/show/1136 Desc ...
- win7系统玩游戏不能全屏的解决办法
1.修改注册表中的显示器的参数设置 Win键+R键,打开运行窗口,输入regedit回车,这样就打开了注册表编辑器,然后,定位到以下位置: HKEY_LOCAL_MACHINE\SYSTEM\ ...
- 【用PS3手柄在安卓设备上玩游戏系列】连接手柄和设备
背景 硬件要求1:PS3 手柄 + 手柄配套的USB线 硬件要求2:已经获得 ROOT 权限并且支持蓝牙的安卓设备 软件要求1:Sixaxis Compatibility Checker PS3 手柄 ...
- UESTC_邱老师玩游戏 2015 UESTC Training for Dynamic Programming<Problem G>
G - 邱老师玩游戏 Time Limit: 3000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Submi ...
- 【特殊的图+DP】【11月校赛】大家一起玩游戏
大家一起玩游戏 Time Limit : 2000/1000ms (Java/Other) Memory Limit : 65536/32768K (Java/Other) Total Submi ...
- 洛谷 P4705 玩游戏 解题报告
P4705 玩游戏 题意:给长为\(n\)的\(\{a_i\}\)和长为\(m\)的\(\{b_i\}\),设 \[ f(x)=\sum_{k\ge 0}\sum_{i=1}^n\sum_{j=1}^ ...
随机推荐
- bootstrap form样式及数据提交
1.基本form布局 想要把form表单弄成两列的表格样式,奈何前端不太懂,记录下样式便于下次使用. form-group :增加盒子的下边界 form-control: 充满整个父元素,并且有换行作 ...
- JY播放器【喜马拉雅FM电脑端,附带下载功能】
今天给大家带来一款神器----JY播放器.可以不用打开网页就在电脑端听喜马拉雅FM的节目,而且可以直接下载,对于我这种强迫症患者来说真的是神器.我是真的不喜欢电脑任务栏上面密密麻麻的. 目前已经支持平 ...
- 【数据结构系列】线段树(Segment Tree)
一.线段树的定义 线段树,又名区间树,是一种二叉搜索树. 那么问题来了,啥是二叉搜索树呢? 对于一棵二叉树,若满足: ①它的左子树不空,则左子树上所有结点的值均小于它的根结点的值 ②若它的右子树不空, ...
- DeepLearning - Regularization
I have finished the first course in the DeepLearnin.ai series. The assignment is relatively easy, bu ...
- PytorchZerotoAll学习笔记(三)--自动求导
Pytorch给我们提供了自动求导的函数,不用再自己再推导计算梯度的公式了 虽然有了自动求导的函数,但是这里我想给大家浅析一下:深度学习中的一个很重要的反向传播 references:https:// ...
- LibLas学习笔记
LibLas学习笔记 las 什么是Las格式 LAS文件格式是数据用户之间交换三维点云数据的公共文件格式. 虽然这种格式主要用于交换激光雷达点云数据,但是它支持交换任何三维的x.y.z 数组. 这 ...
- JavaScript 之 ajax
1. AJAX 的概念 AJAX,即 Asynchronous JavaScript and XML(异步的 JavaScript 和 XML) 同步:前面的代码不执行完毕,后面的代码无法执行 异步: ...
- [leetcode-914-X of a Kind in a Deck of Cards]
In a deck of cards, each card has an integer written on it. Return true if and only if you can choos ...
- JS 操作 checkbox(cc角色管理等)
1.获取选中的权限的个数 var size=$("input[name='privileges']:checked").size();
- pspo过程文档
项目计划总结: 日期/任务 听课 编写程序 阅读相关书籍 日总计 周一 110 60 ...