19-10-24-H
H H H H H H
ZJ一下:
T1只会暴力,测试点分治。
(表示作者的部分分并没有给够,暴力加部分表按测试点分类可以得60吧……)
T2先直接手玩第一个子任务。
然后就$Find$了一个神奇的(?)性质(其实是$dp$的柿子)
发现只要可以从一个必败状态转移到就是必胜的,如果无法从任何一个必败状态转移过来就是仍是必败状态。
于是码好了$\Theta(N^4)$的暴力加一个测试点分治。
T3没啥时间打,连样例都没测$QAQ$(最后果然WA0了)就丢上去了。
Finally:
33
|
Miemeng | 20
03:16:04
|
70
03:16:04
|
0
03:19:46
|
90
03:19:46
|
$T1$为啥只有暴力分?
这是TJ:
T1
直接统各位的$xor$即可;
如何统?
可以发现:
%%%Yu-shi
$$
0000000\\
0000001\\
0000010\\
0000011\\
0000100\\
0000101\\
0000110\\
0000111\\
0001000\\
0001001\\
0001010\\
0001011\\
0001100\\
0001101\\
0001110\\
0001111\\
0010000\\
\vdots
$$
这是有循环节的,直接前缀和做差。
#include <iostream>
#include <cstring>
#include <cstdio>
#define LL long long using namespace std; const int Mod=1e9+7;
LL cna0,cna1,cnb0,cnb1;
LL ans;
int main(){
ios_base::sync_with_stdio(false);
LL T,a,b,dat,lft;
cin>>T;
while(T--){
ans=0;
cin>>a>>b;
for(int k=1;k<=30;k++){
LL i=1<<k;
dat=(a/i)*i;//cout<<"WholeA:"<<dat<<endl;
lft=a-dat; //cout<<"LftA:"<<lft<<endl;
if(lft<=i/2){
cna0=lft;
cna1=0;
}
else{
cna0=i/2;
cna1=lft-i/2;
}
cna0+=dat/2;
cna1+=dat/2; dat=((b+1)/i)*i;//cout<<"WholeB:"<<dat<<endl;
lft=(b+1)-dat; //cout<<"LftB:"<<lft<<endl;
if(lft<=i/2){
cnb0=lft;
cnb1=0;
}
else{
cnb0=i/2;
cnb1=lft-i/2;
}
cnb0+=dat/2;
cnb1+=dat/2; //cout<<"Bit:"<<k<<endl\
<<"A_1:"<<cna1<<endl\
<<"A_0:"<<cna0<<endl\
<<"B_1:"<<cnb1<<endl\
<<"B_0:"<<cnb0<<endl;\
cout<<(cnb1-cna1)<<" "<<(cnb0-cna0)<<endl;
ans+=(cnb1-cna1)%Mod*(cnb0-cna0)%Mod*(i/2)%Mod;
ans%=Mod;
}
cout<<ans*2%Mod<<endl;
}
}
T2
类似埃筛?
直接刷表。
必败情况很少,$N^2$级别。
于是直接用必败去刷表就可以$N^3$过。
#include <iostream>
#include <cstring>
#include <cstdio>
#define N 333 using namespace std; char dp[N][N][N];
int main(){
for(int i=0;i<=300;i++){
for(int j=0;j<=300;j++){
for(int k=0;k<=300;k++){
if(dp[i][j][k]==0){
for(int a=i+1;a<=300;a++)
dp[a][j][k]=1;
for(int a=j+1;a<=300;a++)
dp[i][a][k]=1;
for(int a=k+1;a<=300;a++)
dp[i][j][a]=1;
int lim=300-max(i,j);
for(int a=1;a<=lim;a++)
dp[i+a][j+a][k]=1;
lim=300-max(i,k);
for(int a=1;a<=lim;a++)
dp[i+a][j][k+a]=1;
lim=300-max(k,j);
for(int a=1;a<=lim;a++)
dp[i][j+a][k+a]=1;
lim=300-max(i,max(j,k));
for(int a=1;a<=lim;a++)
dp[i+a][j+a][k+a]=1;
}
}
}
}
ios_base::sync_with_stdio(false);
int T,a,b,c;
cin>>T;
while(T--){
cin>>a>>b>>c;
cout<<(dp[a][b][c]==0?"No":"Yes")<<endl;
}
}
T3
$gugugu$
19-10-24-H的更多相关文章
- Ubuntu 19.10 发布 | 云原生生态周报 Vol. 24
作者 | 木苏.进超.冬岛.元毅.心水.衷源 业界要闻 1.云原生编程语言 Pulumi 1.0 pulumi ,一款中立的开源云开发平台,Pulumi 支持多语言.混合云环境.完全可扩展.初期支持 ...
- python中使用Opencv进行车牌号检测——2018.10.24
初学Python.Opencv,想用它做个实例解决车牌号检测. 车牌号检测需要分为四个部分:1.车辆图像获取.2.车牌定位.3.车牌字符分割和4.车牌字符识别 在百度查到了车牌识别部分车牌定位和车牌字 ...
- 10.24 正睿停课训练 Day8 AM
目录 2018.10.24 正睿停课训练 Day8 AM A 棒棒糖(组合) B 彩虹糖(思路 博弈) C 泡泡糖(DP) 考试代码 A B C 2018.10.24 正睿停课训练 Day8 AM 期 ...
- 程序员的 Ubuntu 19.10 配置与优化指南
原文地址:程序员的 Ubuntu 19.10 配置与优化指南 0x00 环境 CPU: Intel Core i9-9900k GPU: GeForce RTX 2070 SUPER RAM: DDR ...
- 背水一战 Windows 10 (24) - MVVM: 通过 Binding 或 x:Bind 结合 Command 实现,通过非 ButtonBase 触发命令
[源码下载] 背水一战 Windows 10 (24) - MVVM: 通过 Binding 或 x:Bind 结合 Command 实现,通过非 ButtonBase 触发命令 作者:webabcd ...
- table-cell http://www.cnblogs.com/StormSpirit/archive/2012/10/24/2736453.html
http://www.cnblogs.com/StormSpirit/archive/2012/10/24/2736453.html
- 使用mybatis提供的各种标签方法实现动态拼接Sql。使用foreach标签实现遍历查询。比如实现select * from user where id in(1,10,24)这条sql查询语句。
向sql传递数组或List,mybatis使用foreach解析,如下: 需求: 传入多个id查询用户信息,用下边的sql实现: select * from user where id in(1,10 ...
- [Linux] 在 Ubuntu 19.10 上开启 SSH 服务并允许远程登录
在 Ubuntu 19.10 上安装 SSH,并开启服务 0.检查并确认系统当前是否已安装SSH: sudo ps -e | grep ssh 如果只有 ssh-agent 说明 ssh-server ...
- [Linux] 树莓派 4B 安装 Ubuntu 19.10 (Eoan Ermine) IOT 版
硬件:Raspberry Pi 4B系统:Ubuntu 19.10 (Eoan Ermine) for IOT官网:https://ubuntu.com/download/iot/raspberry- ...
- Java习题10.24
Java习题10.24 1. 1,3.connect()与accept():这两个系统调用用于完成一个完整相关的建立,其中connect()用于建立连接.accept()用于使服务器等待来自某客户进程 ...
随机推荐
- VS2010-MFC(文档、视图和框架:分割窗口)
转自:http://www.jizhuomi.com/software/226.html 上一节讲了文档.视图和框架结构中各对象之间的关系,本节主要讲讲在MFC中如何分割窗口. 分割窗口概述 ...
- 搞大数据,你不懂这三大数据处理趋势就OUT了
搞大数据,你不懂这三大数据处理趋势就OUT了 企业数据每年以PB级甚至上百PB爆炸式增长,越来越大的数据量正为扩大分析策略在企业应用软件领域的拓展提供了数据基础,但数据的价值是有时效性的,越早分析越能 ...
- C#实现拍照并且存水印照片
由于一直在高校工作,就涉及到招生工作,招生时候又要收集学生图像采集,所以就随手写了一个图像采集工具,废话不多说,进入正题. 图像采集需要调用摄像头就行拍照操作,网上查了一下资料,需要引用以下3个dll ...
- 豌豆荚Redis集群方案:Codis
Codis简介 Codis是一个分布式Redis解决方案,对于上层的应用来说,连接到CodisProxy和连接原生的RedisServer没有明显的区别(不支持的命令列表),上层应用可以像使用单机的R ...
- 6_4.springboot2.x数据整合springData介绍
介绍 Spring Data 项目的目的是为了简化构建基于Spring 框架应用的数据访问技术,包括非关系数据库.Map-Reduce 框架.云数据服务等等:另外也包含对关系数据库的访问支持. spr ...
- Spark历险记之编译和远程任务提交
Spark简介 Spark是加州大学伯克利分校AMP实验室(Algorithms, Machines, and People Lab)开发通用内存并行计算框架.Spark在2013年6月进入Apach ...
- c语言排序代码实现
关于快速,冒泡,选择,插入等排序,本人用代码实现,均能运行成功. 本文除了排序,针对几种swap函数,也进行了说明,通过汇编代码分析,swap1函数的效率最高. #include<iostrea ...
- arp协议简单介绍
1. 什么是ARP? ARP (Address Resolution Protocol) 是个地址解析协议.最直白的说法是:在IP以太网中,当一个上层协议要发包时,有了该节点的IP地址,ARP就能提供 ...
- 一个页面上调用多个setInterval失效解决办法(使用于同一时间间隔)
将方法封装在一起,只调用一个setInterval window.setInterval( function () { $.ajax({ type: "GET", url: '/M ...
- jvisualvm图解【转】
jvisualvm图解[转] http://blog.csdn.net/a19881029/article/details/8432368 jvisualvm能干什么:监控内存泄露,跟踪垃圾回收, ...