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的更多相关文章

  1. Ubuntu 19.10 发布 | 云原生生态周报 Vol. 24

    作者 | 木苏.进超.冬岛.元毅.心水.衷源 业界要闻 1.云原生编程语言 Pulumi 1.0 pulumi ,一款中立的开源云开发平台,Pulumi 支持多语言.混合云环境.完全可扩展.初期支持 ...

  2. python中使用Opencv进行车牌号检测——2018.10.24

    初学Python.Opencv,想用它做个实例解决车牌号检测. 车牌号检测需要分为四个部分:1.车辆图像获取.2.车牌定位.3.车牌字符分割和4.车牌字符识别 在百度查到了车牌识别部分车牌定位和车牌字 ...

  3. 10.24 正睿停课训练 Day8 AM

    目录 2018.10.24 正睿停课训练 Day8 AM A 棒棒糖(组合) B 彩虹糖(思路 博弈) C 泡泡糖(DP) 考试代码 A B C 2018.10.24 正睿停课训练 Day8 AM 期 ...

  4. 程序员的 Ubuntu 19.10 配置与优化指南

    原文地址:程序员的 Ubuntu 19.10 配置与优化指南 0x00 环境 CPU: Intel Core i9-9900k GPU: GeForce RTX 2070 SUPER RAM: DDR ...

  5. 背水一战 Windows 10 (24) - MVVM: 通过 Binding 或 x:Bind 结合 Command 实现,通过非 ButtonBase 触发命令

    [源码下载] 背水一战 Windows 10 (24) - MVVM: 通过 Binding 或 x:Bind 结合 Command 实现,通过非 ButtonBase 触发命令 作者:webabcd ...

  6. table-cell http://www.cnblogs.com/StormSpirit/archive/2012/10/24/2736453.html

    http://www.cnblogs.com/StormSpirit/archive/2012/10/24/2736453.html

  7. 使用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 ...

  8. [Linux] 在 Ubuntu 19.10 上开启 SSH 服务并允许远程登录

    在 Ubuntu 19.10 上安装 SSH,并开启服务 0.检查并确认系统当前是否已安装SSH: sudo ps -e | grep ssh 如果只有 ssh-agent 说明 ssh-server ...

  9. [Linux] 树莓派 4B 安装 Ubuntu 19.10 (Eoan Ermine) IOT 版

    硬件:Raspberry Pi 4B系统:Ubuntu 19.10 (Eoan Ermine) for IOT官网:https://ubuntu.com/download/iot/raspberry- ...

  10. Java习题10.24

    Java习题10.24 1. 1,3.connect()与accept():这两个系统调用用于完成一个完整相关的建立,其中connect()用于建立连接.accept()用于使服务器等待来自某客户进程 ...

随机推荐

  1. dos中文显示乱码怎么办?

    其实只需要一条命令 chcp 65001 执行该操作后,代码页就被变成UTF-8了 也可是GBK,  命令式:  chcp  936 2.修改窗口属性,改变字体 在命令行标题栏上点击右键,选择&quo ...

  2. linux watch命令查看网卡流量

    watch命令可以反复的执行一个命令,默认时间间隔为2秒钟.TX是发送(transport),RX是接收(receive)RX bytes:总下行流量TX bytes:总上行流量 可以每隔两秒监视网络 ...

  3. socket2里面,有些函数带WSA开头,有些不带。请问有何区别?

    WSASocket可以使用WinSock特有功能,比如重叠IO,用dwflags指定.    WSA的A是指api,用于区别spi,因为在spi中还有wspsocket,wspaccept等... 在 ...

  4. System.Web.Mvc.IController.cs

    ylbtech-System.Web.Mvc.IController.cs 1.程序集 System.Web.Mvc, Version=5.2.3.0, Culture=neutral, Public ...

  5. 通过aapt查看apk包名和第一个启动的activity

    步骤: ps:aapt是sdk 自带的一个工具,在sdk\builds-tools目录下: 1. cmd启动控制台, 默认是c盘,输入“d:” 即可转到D盘目录 2. 到D盘后 输入cd 子文件目录转 ...

  6. java-day04

    IntelliJ快捷键 导入包 alt + enter 删除光标所在行 ctrl + y 复制光标所在行 ctrl + d 格式代码 ctrl + alt + l 单行注释 ctrl + / 多行注释 ...

  7. js基础应用-打字机,震动窗口

    js基础应用一,窗口震动 html+js代码: <!DOCTYPE html> <html> <head> <meta charset="UTF-8 ...

  8. <jquery>基本的模态框

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. C# 中的三个高级参数 ref

    今天在浏览博文时,看到这篇文章:C#中的ref 传进出的到底是什么 ? 在传对象时使用ref的疑问 引用类型就传的就是地址,值类型传的就是值,可是还仍有那么多人迷惑,网上虽然流传着很多ref 的相关文 ...

  10. 2019-8-31-dotnet-core-发布只带必要的依赖文件

    title author date CreateTime categories dotnet core 发布只带必要的依赖文件 lindexi 2019-08-31 16:55:58 +0800 20 ...