Link:

ARC 066 传送门

C:

如果存在可行方案则答案为$2^{n/2}$

#include <bits/stdc++.h>

using namespace std;
#define X first
#define Y second
typedef long long ll;
typedef pair<int,int> P;
const int MAXN=1e5+,MOD=1e9+;
int n,x,res[MAXN]; int main()
{
scanf("%d",&n);
for(int i=;i<=n;i++)
{
scanf("%d",&x);
int rk=(n-+x)/;
if(!res[rk+]) res[rk+]=i;
else if(!res[n-rk]) res[n-rk]=i;
else return puts(""),;
}
int res=;
for(int i=;i<=n/;i++) (res*=)%=MOD;
printf("%d",res);
return ;
}

Problem C

D:

挺不错的一道数位$dp$

由于无法直接计算$sum$和$xor$的对数,因此考虑枚举$a,b$,而将$sum,xor\le n$作为限制条件

又因为公式:$a+b=aXORb+2*(a\&b)$,所以$a+b\le aXORb$,只考虑$a+b$的限制即可

此时问题转化为对于每个$sum\le n$求$xor$的取值个数

这样就可以用$dp[i][s]$表示前$i$位确定,$a+b$的和为$s$的个数,每次分$a,b$在该位上总共有几个1转移

(按每位1的个数转移才不会考虑异或与和同时相同的情况!)

但这样复杂度是不对的,在枚举$s$上明显花费了不必要的时间

根据一般数位$dp$记录上限的思想,如果前$i$位的$n-s\ge 2$,这些数以后都保证合法,就能统一计算了

这样就从$dp[i][s]$变成了$dp[i][0/1/2]$

#include <bits/stdc++.h>

using namespace std;
#define X first
#define Y second
typedef long long ll;
typedef pair<int,int> P;
#define MAX_D 64
#define MOD ((ll)1e9 + 7)
ll N,dp[MAX_D][],res;int nxt; int main()
{
scanf("%lld",&N);
dp[MAX_D-][]=;
for(int i=MAX_D-;i>;i--)
for(int j=; j <= ; j++)
for(int k=;k<=;k++)
{
nxt=j*+((N>>(i-))&)-k;
if (nxt<) continue;
nxt=nxt>?:nxt;
(dp[i-][nxt]+=dp[i][j])%=MOD;
}
res=;
for (int i=;i<=;i++) (res+=dp[][i])%=MOD;
printf("%lld\n", res);
return ;
}

Solution A

从后往前用记忆化搜索的形式写起来更加方便

一开始将上限值就设为$n$,每次确定最后一位取几个以后去掉最后一位,不用考虑和的合法性了

#include <bits/stdc++.h>

using namespace std;
#define X first
#define Y second
typedef long long ll;
typedef pair<int,int> P;
const int MOD=1e9+;
map<ll,ll> dp;ll n; ll dfs(ll x)
{
if(dp.count(x)) return dp[x];
return dp[x]=(dfs(x>>)+dfs((x-)>>)+dfs((x-)>>))%MOD;
} int main()
{
scanf("%lld",&n);
dp[]=;dp[]=;
printf("%lld",dfs(n));
return ;
}

Solution B

E:

首先要观察出几点性质:

1、只有在减号后可能加括号

2、括号不可能嵌套超过两层,否则可以转化为只有两层的简化情况

这样就可以记录$dp[0/1/2]$分别表示当前还有几个左括号未匹配的最大值来$dp$了

#include <bits/stdc++.h>

using namespace std;
typedef long long ll;
int n,x;char op;ll dp[],nxt[]; int main()
{
scanf("%d%d",&n,&dp[]);
dp[]=dp[]=-1ll<<;
for(int i=;i<n;i++)
{
scanf(" %c%d",&op,&x);
if(op=='-') x=-x;
nxt[]=dp[]+x,nxt[]=dp[]-x,nxt[]=dp[]+x;
dp[]=max(nxt[],max(nxt[],nxt[]));
if(op=='+') dp[]=max(nxt[],nxt[]),dp[]=nxt[];
else dp[]=dp[],dp[]=max(nxt[],nxt[]);
}
printf("%lld",dp[]);
return ;
}

Solution A

其实也可以不用$dp$,考虑如果在某个减号后加了第一个括号的最优解

发现此时能保证将下一个减号后的值都变为正贡献,但对当前位到下一个减号间的值是无能为力的

这样枚举第一个括号的位置对答案更新即可

#include <bits/stdc++.h>

using namespace std;
#define X first
#define Y second
typedef long long ll;
typedef pair<int,int> P;
const int MAXN=1e5+;
char op[MAXN];
int n,dat[MAXN],nxt[MAXN],fst;
ll suf[MAXN],cur,res=-1ll<<; int main()
{
scanf("%d%d",&n,&fst);
for(int i=;i<n;i++)
scanf(" %c%d",&op[i],&dat[i]);
cur=n;
for(int i=n-;i;i--)
{
suf[i]=suf[i+]+dat[i];
if(op[i]=='-') nxt[i]=cur,cur=i;
}
cur=;
for(int i=;i<n;i++)
if(op[i]=='-')
res=max(res,cur-suf[i]+*suf[nxt[i]]),cur-=dat[i];
else cur+=dat[i];
res=max(res,cur);
printf("%lld",res+fst);
return ;
}

Solution B

F:

[ARC 066] Tutorial的更多相关文章

  1. AtCoder Regular Contest

    一句话题解 因为上篇AGC的写的有点长……估计这篇也短不了所以放个一句话题解方便查阅啥的吧QwQ 具体的题意代码题解还是往下翻…… ARC 058 D:简单容斥计数. E:用二进制表示放的数字,然后状 ...

  2. HTML5 Canvas Arc Tutorial

    HTML5 Canvas Arc Tutorial HTML5 Canvas Arc Tutorial  

  3. [Hive - Tutorial] Built In Operators and Functions 内置操作符与内置函数

    Built-in Operators Relational Operators The following operators compare the passed operands and gene ...

  4. 【转】Enable ARC in a Cocos2D Project: The Step-by-Step-How-To-Guide Woof-Woof!

    On April 5, 2012, in idevblogaday, by Steffen Itterheim http://www.learn-cocos2d.com/2012/04/enablin ...

  5. GDI+ Tutorial for Beginners

    原文 GDI+ Tutorial for Beginners GDI+ is next evolution of GDI. Using GDI objects in earlier versions ...

  6. MapServer Tutorial——MapServer7.2.1教程学习——第一节用例实践:Example1.7 Adding a wms layer

    MapServer Tutorial——MapServer7.2.1教程学习——第一节用例实践:Example1.7 Adding a wms layer 前言 Add OGC WMS Layers( ...

  7. MapServer Tutorial——MapServer7.2.1教程学习——第一节用例实践:Example1.6 Defining Projections and Extents

    MapServer Tutorial——MapServer7.2.1教程学习——第一节用例实践:Example1.6 Defining Projections and Extents 一.前言 当在m ...

  8. MapServer Tutorial——MapServer7.2.1教程学习——第一节用例实践:Example1.5 Adding a raster layer

    MapServer Tutorial——MapServer7.2.1教程学习——第一节用例实践:Example1.5 Adding a  raster layer 一.前言 MapServer不仅支持 ...

  9. Instruments Tutorial for iOS: How To Debug Memory Leaks【转】

    If you're new here, you may want to subscribe to my RSS feed or follow me on Twitter. Thanks for vis ...

随机推荐

  1. 【BZOJ】1635: [Usaco2007 Jan]Tallest Cow 最高的牛

    [题意]n头牛,其中最高h.给定r组关系a和b,要求满足h[b]>=h[a]且a.b之间都小于min(h[a],h[b]),求第i头牛可能的最高高度. [算法]差分 [题解]容易发现r组关系只能 ...

  2. python keras YOLOv3实现目标检测

    1.连接 https://www.jianshu.com/p/3943be47fe84

  3. poj 1797

    2013-09-08 09:48 最大生成树,输出生成树中最短的边儿即可 或者对边儿排序,二份答案+BFS判断是否1连通N 时间复杂度都是O(NlogN)的 附最大生成树pascal代码 //By B ...

  4. Maven学习笔记(一)

    我们暂且可以把Maven理解成是一个项目构建与依赖管理的工具   为什么选用maven? 约定(惯例)优先原则,默认限定了项目目录结构 提供三方依赖管理(解决了依赖维护的问题) 提供了一致的项目构建管 ...

  5. Sqlmap使用教程

    sqlmap也是渗透中常用的一个注入工具,其实在注入工具方面,一个sqlmap就足够用了,只要你用的熟,秒杀各种工具,只是一个便捷性问题,sql注入另一方面就是手工党了,这个就另当别论了. 今天把我一 ...

  6. 測試 battery capacity curve 的負載

    昨天有同事問說, 他要測試 battery capacity curve, 並且負載要使用 33mA, 於是我想到有一個 apk 名稱為 快速放電 (最下方),可以控制 cpu 的 load, 他試了 ...

  7. MACACA===gradle下载和安装

    gradle下载地址: http://services.gradle.org/distributions/ 或者直接点击这个: http://services.gradle.org/distribut ...

  8. 在linux内核中获得比jiffies精度更高的时间值【转】

    转自:http://blog.chinaunix.net/uid-20672257-id-2831219.html 内核一般通过jiffies值来获取当前时间.尽管该数值表示的是自上次系统启动到当前的 ...

  9. selenium WebElement 的属性和方法 属性

    tag_name 标签名,例如 'a'表示<a>元素get_attribute(name) 该元素name 属性的值text 该元素内的文本,例如<span>hello< ...

  10. const 引用的分析

    const 引用: 在初始化常量引用时,允许用任意表达式作为初始值,只要该表达式的结果能转换成引用的类型即可.尤其,允许为一个常量引用绑定非常量的对象.字面值,甚至是一个表达式.我们来看 const ...