不想欠题了..... 多打打CF才知道自己智商不足啊...

A. Vladik and flights

给你一个01串  相同之间随便飞 没有费用 不同的飞需要费用为  abs i-j

真是题意杀啊,,,实际上我们只考虑01转换的代价一定为1如果目的地和起点相同  费用为0

不相同  肯定为1  因为0旁边必然有1

#include <cstdio>
#include <iostream>
#include <algorithm>
#include <vector>
#include <set>
#include <string.h>
#include <cctype>
#include <climits>
using namespace std;
typedef long long ll;
template <class T>
inline bool r(T &ret)
{
char c;
int sgn;
if (c = getchar(), c == EOF)
{
return ; //EOF
}
while (c != '-' && (c < '' || c > ''))
{
c = getchar();
}
sgn = (c == '-') ? - : ;
ret = (c == '-') ? : (c - '');
while (c = getchar(), c >= '' && c <= '')
{
ret = ret * + (c - '');
}
ret *= sgn;
return ;
}
const int N = 1e5+;
char ch[N];
int main()
{
int n;
r(n);
int x,y;
r(x),r(y);
scanf("%s",ch+);
if(ch[x]==ch[y])
{
printf("0\n");
}
else{
printf("1\n");
}
return ;
}

zz

B. Chloe and the sequence

给一个n,然后按照 1  121 1213121 的第n个串

那么肯定是二分n次必得....  赛场拿python写的   (L+R)没加括号T1

n,k = map(int, input().split())
def calc(k):
L =
R = **n
M = L+R//
ans =
while(k!=M):
if(k>M):
L = M
else:
R = M
M = (L+R)//
ans+=
print(n-ans)
calc(k)

Py

C. Vladik and fractions

问2/n能不能由1/a+1/b+1/c(a,b,c互不相同) 太粗心,没看到互不相同 wa1 没特判1 被hack 1

手推 a = n b = n+1 c = n*(n+1)

n=1分不出的

#include <cstdio>
#include <iostream>
#include <algorithm>
#include <vector>
#include <set>
#include <string.h>
#include <cctype>
#include <climits>
using namespace std;
typedef long long ll;
template <class T>
inline bool r(T &ret)
{
char c;
int sgn;
if (c = getchar(), c == EOF)
{
return ; //EOF
}
while (c != '-' && (c < '' || c > ''))
{
c = getchar();
}
sgn = (c == '-') ? - : ;
ret = (c == '-') ? : (c - '');
while (c = getchar(), c >= '' && c <= '')
{
ret = ret * + (c - '');
}
ret *= sgn;
return ;
} int main()
{
int n;
r(n);
if(n==) printf("-1");
else printf("%d %d %d\n",n,n+,n*(n+));
return ;
}

AC

D.Chloe and pleasant prizes

带权有根树  选两个不相交子树的之和最大,裸DFS。

吐槽一下自己奇差无比的代码。。。两个dfs才完成任务...

还因为各种写搓  wa了3次

#include <stdio.h>
#include <iostream>
#include <algorithm>
#include <limits.h>
#include <vector>
using namespace std;
typedef long long ll;
const int N = 2e5+;
vector<int>g[N];
ll sum[N];
ll son[N];
int a[N];
void push(int x,int y){g[x].push_back(y);g[y].push_back(x);}
bool flag = true;
void UMAX(ll& a,ll& b,ll c){
if(c>a)
{
b = a;
a = c;
}
else{
if(c>=b)
{
b = c;
}
}
}
ll dfs(int now,int pre)
{
sum[now] += a[now]; bool mk = true;
for(int i=;i<g[now].size();i++)
{
if(g[now][i]==pre) continue;
ll val = dfs(g[now][i],now);
sum[now] += val;
if(!mk)son[now] = max(son[now],son[g[now][i]]);
else{
mk = false;
son[now] = son[g[now][i]];
}
}
if(mk)son[now] = a[now];
son[now] = max(son[now],sum[now]);
return sum[now];
}
ll ans = LONG_LONG_MIN;
void F(int now,int pre)
{
//cout<<now<<endl;
ll a = LONG_LONG_MIN;
ll b = LONG_LONG_MIN;
for(int i=;i<g[now].size();i++)
{
if(pre==g[now][i]) continue;
UMAX(a,b,son[g[now][i]]);
F(g[now][i],now);
}
//if(now==4) cout<<a<<" "<<b<<endl;
if(b!=LONG_LONG_MIN)ans = max(ans,a+b);
}
int main()
{
int n;
scanf("%d",&n);
for(int i=;i<=n;i++)
{
scanf("%d",&a[i]);
}
int x,y;
for(int i=;i<n;i++)
{
scanf("%d%d",&x,&y);
push(x,y);
}
dfs(,-);
/*
for(int i=1;i<=n;i++)
printf("%d\t",i);
printf("\n");
for(int i=1;i<=n;i++)
printf("%I64d\t",sum[i]);
printf("\n");
for(int i=1;i<=n;i++)
printf("%I64d\t",son[i]);
printf("\n");
//*/
F(,-);
if(ans==LONG_LONG_MIN)
printf("Impossible\n");
else{
printf("%I64d\n",ans);
}
return ;
}

AC代码

贴一下陈老师的代码....

#include<cstdio>
#include<algorithm>
typedef long long ll;
const int N=;
const ll inf=1LL<<;
int n,i,x,y,a[N],g[N],v[N<<],nxt[N<<],ed;ll f[N],dp[N],ans=-inf;
inline void add(int x,int y){v[++ed]=y;nxt[ed]=g[x];g[x]=ed;}
void dfs(int x,int y){
f[x]=a[x];
dp[x]=-inf;
for(int i=g[x];i;i=nxt[i]){
int u=v[i];
if(u==y)continue;
dfs(u,x);
f[x]+=f[u];
if(dp[x]>-inf)ans=std::max(ans,dp[x]+dp[u]);
dp[x]=std::max(dp[x],dp[u]);
}
dp[x]=std::max(dp[x],f[x]);
}
int main(){
scanf("%d",&n);
for(i=;i<=n;i++)scanf("%d",&a[i]);
for(i=;i<n;i++)scanf("%d%d",&x,&y),add(x,y),add(y,x);
dfs(,);
if(ans>-inf)printf("%I64d",ans);else puts("Impossible");
}

claris

 
 

E. Vladik and cards

题意给以一个1-8组成的串  选出一个子串(在原串中可以不连续)  选出来的串 每个数相同的一定相邻  而且 每种数的个数相差不超过1

比赛时只想到DFS的解,后来证实是错的

后来看别人的代码一脸蒙=。=... 后来一神说了两个数组的作用才明白...就这样   参考claris的写法

而且....

这样也写了好久  而且还少更新状态   长度可以为0......

#include<cstdio>
#include<cstring>
void Min(int &a,int b) {if(a>b) a=b;}
void Max(int &a,int b) {if(a<b) a=b;}
const int maxn = ;
int cnt[];
int g[maxn][maxn][];//i j k
int dp[][];//i 选择方案 j 代表 长度的集合个数 长度最多n/8+1
int val[maxn];
int n;
int main()
{
scanf("%d",&n);
for(int i=;i<=n;i++) scanf("%d",&val[i]),val[i]--;
for(int i=;i<=n;i++)
{
for(int j=;j<=n+;j++)
for(int k=;k<=;k++) g[i][j][k] = maxn;
memset(cnt,,sizeof(cnt));
for(int j=i;j<=n;j++)
g[i][++cnt[val[j]]][val[j]] = j;
}
int ans = ;
for(int i=;i*<=n;i++)//长度
{
for(int j=;j<;j++)
for(int k=;k<=;k++)
dp[j][k] = maxn;
dp[][] = ; //从1开始
for(int j=;j<;j++)//选择方案
{
for(int k=;k<=;k++)//
{
if(dp[j][k]>n)continue;
for(int l=;l<;l++)
{
if((<<l)&j) continue;
Min(dp[j|(<<l)][k],g[dp[j][k]][i][l]+);
Min(dp[j|(<<l)][k+],g[dp[j][k]][i+][l]+);
}
}
}
for(int j=;j<=;j++) if(dp[][j]<n+){
Max(ans,j+*i);
}
}
printf("%d\n",ans);
return ;
}

状压DP

Codeforces Round #384 (Div. 2) //复习状压... 罚时爆炸 BOOM _DONE的更多相关文章

  1. Codeforces Round #384(div 2)

    A 题意:有n个机场处于一直线上,可两两到达,每个机场只可能属于两家公司中的一家(用0,1表示),现在要从a机场到b机场,可任意次转机.若机场i与机场j从属同一公司,则费用为0,否则费用为1.问最小费 ...

  2. Codeforces Round #384 (Div. 2) E

    给出n个数字 1-8之间 要求选出来一个子序列 使里面1-8的数字个数 极差<=1 并且相同数字必须相邻(112 可以但是121不行)求这个子序列的最长长度 一道状压dp 看不懂别人的dp思想. ...

  3. Codeforces Round #384 (Div. 2) E. Vladik and cards 状压dp

    E. Vladik and cards 题目链接 http://codeforces.com/contest/743/problem/E 题面 Vladik was bored on his way ...

  4. Codeforces Round #384 (Div. 2)D - Chloe and pleasant prizes 树形dp

    D - Chloe and pleasant prizes 链接 http://codeforces.com/contest/743/problem/D 题面 Generous sponsors of ...

  5. Codeforces Round #384 (Div. 2) C. Vladik and fractions 构造题

    C. Vladik and fractions 题目链接 http://codeforces.com/contest/743/problem/C 题面 Vladik and Chloe decided ...

  6. Codeforces Round #384 (Div. 2)B. Chloe and the sequence 数学

    B. Chloe and the sequence 题目链接 http://codeforces.com/contest/743/problem/B 题面 Chloe, the same as Vla ...

  7. Codeforces Round #384 (Div. 2) A. Vladik and flights 水题

    A. Vladik and flights 题目链接 http://codeforces.com/contest/743/problem/A 题面 Vladik is a competitive pr ...

  8. Codeforces Round #384 (Div. 2) C. Vladik and fractions(构造题)

    传送门 Description Vladik and Chloe decided to determine who of them is better at math. Vladik claimed ...

  9. Codeforces Round #384 (Div. 2) B. Chloe and the sequence(规律题)

    传送门 Description Chloe, the same as Vladik, is a competitive programmer. She didn't have any problems ...

随机推荐

  1. 在网页中怎样给已发布的Flash添加链接的方法(zhuan)

    因为网页中的 Flash 是以控件形式出现的,优先级别较高,所以直接对它加链接是无效的,不过可以用按钮控件 BUTTON 来实现. 具体步骤 1.直接在按钮上加上onClick事件打开指定页面: &l ...

  2. Thinkphp的单字母函数整理

    有人不太喜欢TP这种单字母函数,其实这也是TP的一个特色,如果理解了这些函数的作用,不管是背,还是写,都是非常方便的,接下来我们以字母顺序开始.A函数 B函数 C函数 D函数 F函数 L函数 R函数 ...

  3. 采用UDP协议实现PIC18F97J60 ethernet bootloader

    了解更多关于bootloader 的C语言实现,请加我QQ: 1273623966 (验证信息请填 bootloader),欢迎咨询或定制bootloader(在线升级程序). TCP/IP Stac ...

  4. A quick introduction to HTML

    w3c reference : https://www.w3.org/TR/2014/REC-html5-20141028/introduction.html#writing-secure-appli ...

  5. 引入math模块中的log()方法,导致"TypeError: return arrays must be of ArrayType",什么原因?

    from math import log from numpy import *import operator ............ re = log(pro,2) ............ Ty ...

  6. 运行R 报错R cannot R_TempDir, 继而发现/dev/mapper/VG00-LV01 磁盘空间已满

    今天在运行R脚本的时候报了个错:Fatal error: cannot create 'R_TempDir'.排除了是自己写的代码的问题,想着应该是某个没见过的原因,google之,发现网上的说法是/ ...

  7. javascript获取当前时间

    function getCurrentDate(){ var myDate = new Date(); var month = myDate.getMonth()+1; var day = myDat ...

  8. ffmpeg基础

    背景知识ffmpeg是一款领先的流媒体处理框架,支持编码,解码,转码等功能并可以在linux, Mac OS X, Microsoft Windows编译运行,用它做播放器的有:ffplay,射手播放 ...

  9. Windows 10设置桌面图标间距、窗口的背景颜色、选中文字的背景颜色

    Windows 10取消了“高级外观设置”(或者叫“窗口颜色和外观”设置),想调整一些参数只能进注册表了. 修改后可能需要注销或重启才能生效. 按Win+R,然后输入regedit进入注册表编辑器. ...

  10. python--day2--基础数据类型与变量

    笔者:QQ:   360212316 python控制语句 for循环语句示例: for i in range(10): print(i) for循环语句示例1: for i in range(10) ...