传送门

考场上只会爆搜……觉得重复状态其实有很多但不知道怎么记忆化,结果……

  • 对于类似这样n不算太小但只有二三十,而重复状态极多的题其实也是可以跑状压/记搜的,状态可以开map存

然后就是爆搜,就没什么了……

这题\(k=n-1\)其实有特解……白优化了半天hash 考虑\(k=n-1\)其实就是有一个点可以任选

upd: 其实不用特解,移位卡常可以过

Code:

#include <bits/stdc++.h>
using namespace std;
#define INF 0x3f3f3f3f
#define N 100
#define ll long long
#define ld long double
#define usd unsigned
#define ull unsigned long long
//#define int long long
#define max(a, b) ((a)>(b)?(a):(b))
#define reg register int inline int read() {
int ans=0, f=1; char c=getchar();
while (!isdigit(c)) {if (c=='-') f=-f; c=getchar();}
while (isdigit(c)) {ans=(ans<<3)+(ans<<1)+(c^48); c=getchar();}
return ans*f;
} int n, k;
char s[N]; namespace force{
int v[N];
bool vis[N];
double dfs(int u, int sum) {
//cout<<"dfs "<<u<<' '<<sum<<endl;
if (u>k) return 1.0*sum;
int lim=n-u+1, bkpa, bkpb, cnt;
int a, b;
double ans=0; double t1, t2;
for (int i=1; i<=lim; ++i) {
cnt=0; for (int j=1; j<=n; ++j) {if (!vis[j]) {if (++cnt==i) {vis[j]=1; a=v[j]; bkpa=j;}}}
t1=dfs(u+1, sum+(a==0));
//cout<<a<<' '<<bkpa<<endl;
vis[bkpa]=0;
cnt=0; for (int j=n; j; --j) {if (!vis[j]) {if (++cnt==i) {vis[j]=1; b=v[j]; bkpb=j;}}}
t2=dfs(u+1, sum+(b==0));
vis[bkpb]=0;
//cout<<"u, i: "<<u<<' '<<i<<' '<<max(t1, t2)<<endl;
ans+=max(t1, t2)/(1.0*lim);
}
return ans;
}
void solve() {
for (int i=1; i<=n; ++i)
if (s[i]=='W') v[i]=0;
else v[i]=1;
//cout<<1<<endl;
printf("%.10lf\n", dfs(1, 0));
exit(0);
}
} namespace task2{
void solve() {
int cnt=0;
for (int i=1; i<=n; ++i) if (s[i]=='W') ++cnt;
printf("%.10lf\n", double(cnt));
exit(0);
}
} namespace task3{
void solve() {
int cntw=0;
for (int i=1; i<=n; ++i) if (s[i]=='W') ++cntw;
if (!cntw) {puts("0.0000000000"); exit(0);}
if (cntw==n) {printf("%.10lf\n", double(k)); exit(0);}
if (cntw==n-1 && n%2==0) {printf("%.10lf\n", double(k)); exit(0);}
if (cntw==n-1 && n%2) {printf("%.10lf\n", double(k-1)/double(k)); exit(0);}
if (k==n-1) {printf("%.10lf\n", double(min(cntw, n-1))); exit(0);}
force::solve();
}
} namespace task{
//unordered_map<pair<int, int>, double> mp;
struct ele{int a, b; ele(){} ele(int a_, int b_):a(a_),b(b_){}};
inline bool operator == (ele a, ele b) {return a.a==b.a&&a.b==b.b;}
struct hush_table{
static const int SIZE=50000100;
int head[SIZE], size;
//int cnt[SIZE];
struct edge{double dat; ele p; int next;}e[5000010];
inline bool find(ele q) {
ll t=(998244353ll*q.a*q.b+(q.a))%SIZE;
//cout<<"t: "<<t<<endl;
for (int i=head[t]; i; i=e[i].next)
if (q==e[i].p) return 1;
return 0;
}
inline double operator [] (ele q) {
ll t=(998244353ll*q.a*q.b+(q.a))%SIZE;
//cout<<"t: "<<t<<endl;
for (int i=head[t]; i; i=e[i].next)
if (q==e[i].p) return e[i].dat;
}
inline void add(ele q, double dat) {
//cout<<"size: "<<size<<endl;
ll t=(998244353ll*q.a*q.b+(q.a))%SIZE;
//++cnt[t];
//cout<<"t: "<<t<<endl;
edge* k=&e[++size]; k->dat=dat; k->p=q; k->next=head[t]; head[t]=size;
//if (size > 10000010) cout<<"error"<<endl;
}
void check() {
//int maxn=0;
//for (int i=0; i<SIZE; ++i) maxn=max(maxn, cnt[i]);
//cout<<"maxn: "<<maxn<<endl;
//cout<<"size: "<<size<<endl;
}
}mp;
int v[N];
double dfs(int u, int s) {
//cout<<"dfs "<<u<<' '<<bitset<10>(s)<<endl;
if (u>k) return 0.0;
ele p(u, s);
//cout<<"go to find"<<endl;
if (mp.find(p)) return mp[p];
//cout<<"not return "<<endl;
int lim=n-u+1, cnt;
int a, b, s2, s3;
double ans=0; double t1, t2;
for (reg i=1; i<=lim/2; ++i) {
a=(s&(1<<(i-1)))?1:0;
cnt=s2=0;
#if 0
for (reg j=0; j<lim; ++j)
if (j!=i-1) {
if (s&(1<<j)) s2|=(1<<cnt);
++cnt;
}
#endif
s2=((s>>i)<<(i-1));
s2|=(s&((1<<(i-1))-1));
//cout<<"s2, s3: "<<bitset<5>(s2)<<' '<<bitset<5>(s3)<<endl;
//assert(s2==s3);
t1=dfs(u+1, s2)+(a==0); b=(s&(1<<(lim-i)))?1:0;
cnt=s2=0;
#if 0
for (reg j=0; j<lim; ++j)
if (j!=lim-i) {
if (s&(1<<j)) s2|=(1<<cnt); //, cout<<"1<<"<<(cnt)<<endl;
++cnt;
}
#endif
s2=((s>>(lim-i+1))<<(lim-i));
s2|=(s&((1<<(lim-i))-1));
//cout<<"s2, s3: "<<bitset<5>(s2)<<' '<<bitset<5>(s3)<<endl;
//assert(s2==s3);
t2=dfs(u+1, s2)+(b==0); ans+=max(t1, t2)/(0.5*lim);
}
if (lim&1) {
int i=lim/2+1;
a=(s&(1<<(i-1)))?1:0;
cnt=s2=0;
#if 0
for (reg j=0; j<lim; ++j)
if (j!=i-1) {
if (s&(1<<j)) s2|=(1<<cnt);
++cnt;
}
#endif
s2=((s>>i)<<(i-1));
s2|=(s&((1<<(i-1))-1));
t1=dfs(u+1, s2)+(a==0);
ans+=t1/(1.0*lim);
}
//cout<<"go to add"<<endl;
mp.add(p, ans);
//cout<<"return "<<endl;
return ans;
}
void solve() {
int ss=0;
for (int i=1; i<=n; ++i)
if (s[i]=='W') v[i-1]=0;
else v[i-1]=1, ss|=(1<<(i-1));
//cout<<1<<endl;
printf("%.10lf\n", dfs(1, ss));
mp.check();
exit(0);
}
} signed main()
{
#ifdef DEBUG
freopen("1.in", "r", stdin);
#endif n=read(); k=read();
scanf("%s", s+1);
if (k==0) {puts("0.0000000000"); return 0;}
if (k==n || (0&&k==n-1)) task2::solve();
//if (n>=10) task3::solve();
//force::solve();
task::solve(); return 0;
}

题解 v的更多相关文章

  1. FZU 2277 Change(dfs序+树状数组)

    Problem Description There is a rooted tree with n nodes, number from 1-n. Root’s number is 1.Each no ...

  2. 【AtCoder】Dwango Programming Contest V题解

    A - Thumbnail 题意简述:给出N个数,找出N个数中和这N个数平均值绝对值最小的数 根据题意写代码即可= = #include <bits/stdc++.h> #define f ...

  3. csp-s模拟测试53u,v,w题解

    题面:https://www.cnblogs.com/Juve/articles/11602450.html u: 用差分优化修改 二维差分:给(x1,y1),(x2,y2)加上s: $d[x1][y ...

  4. 题解 SP2916 【GSS5 - Can you answer these queries V】

    前言 最近沉迷于数据结构,感觉数据结构很有意思. 正文 分析 先来分类讨论一下 1. \(x2<y1\) 如果 \(y1<x2\) 的话,答案 \(=\max \limits_{ y1 \ ...

  5. [V&N2020 公开赛] Web misc部分题解

    0x00 前言 写了一天题目,学到了好多东西, 简单记录一下 0x01 Web HappyCTFd 直接使用网上公开的cve打: 解题思路:先注册一个admin空格账号,注意这里的靶机无法访问外网,邮 ...

  6. 题解报告:hdu1995汉诺塔V(递推dp)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1995 Problem Description 用1,2,...,n表示n个盘子,称为1号盘,2号盘,. ...

  7. 「题解」「UOJ-164」「清华集训2015」V

    目录 题目 原题目 简要题目 正解 这道题题目简洁新颖,吸引读者阅读兴趣... 题目 原题目 点这里 简要题目 需要你维护长度为n的序列并支持下列操作: 区间加法: 区间赋值: 区间每个 \(a_i\ ...

  8. v&n赛 内存取证题解(已更新)

    题目是一个raw的镜像文件 用volatility搜索一下进程 有正常的notepad,msprint,还有dumpit和truecrypt volatility -f mem.raw --profi ...

  9. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

随机推荐

  1. ROS2学习之旅(14)——编写简单的发布者和订阅者(C++)

    节点是通过ROS Graph进行通信的可执行进程.在本文中,节点将通过话题以字符串消息的形式相互传递信息.这里使用的例子是一个简单的"talker"和"listener& ...

  2. java基础---设计模式(2)

    结构型模式 出处:https://blog.csdn.net/zhangerqing/article/details/8239539 一.适配器模式 适配器模式将某个类的接口转换成客户端期望的另一个接 ...

  3. MVP on Board 没用小技巧 👌

    七月入选了微软 MVP,本文记录 on board 过程中遇到的小问题和没用小技巧. MVP Portal 当你收到来自微软的确认邮件之后,你将正式被接纳为微软现任 MVP 的一员.从此刻开始,你便拥 ...

  4. Linux磁盘配额与LVM

    一.LVM概述  逻辑卷管理 Logical Volume Manager二.LVM机制的基本概念三.LVM的管理命令  ① 主要命令  ② ==LVM逻辑卷操作流程==  ③ 举例四.磁盘配额概述  ...

  5. 如何使用Meter-WebSocketSampler

    安装 JMeter-WebSocketSampler 下载最新的 JMeter-WebSocketSampler,如 JMeterWebSocketSamplers-1.2.1.jar. 下载地址:h ...

  6. TOSCA自动化测试工具

    TOSCA由德国公司Tricentis研发,提供英文和德语两种版本. 目前他们的网上培训课程大约是2000一套,从初级到高级,从工程师到BA,有技术,也有测试管理. TOSCA的思想是,不用会编程的测 ...

  7. Kubernetes实战:高可用集群的搭建和部署

    摘要:官方只提到了一句"使用负载均衡器将 apiserver 暴露给工作节点",而这恰恰是部署过程中需要解决的重点问题. 本文分享自华为云社区<Kubernetes 高可用集 ...

  8. js检测客户端是否安装

    前言 需求背景:一个web下载页面,需要检测pc是否安装了客户端软件(windows软件).网页上有一个打开客户端按钮.若安装了客户端软件,则直接打开,否则下载软件.支持web下载页面在iframe下 ...

  9. debian9 独显安装后进入不了桌面解决方法

    # apt-get purge nvidia. # /etc/init.d/sddm stop (sddm for kde) # aptitude --without-recommends insta ...

  10. 浅析VO、DTO、DO、PO的概念、区别和用处(八)

    本篇文章主要讨论一下我们经常会用到的一些对象:VO.DTO.DO和PO. 由于不同的项目和开发人员有不同的命名习惯,这里我首先对上述的概念进行一个简单描述,名字只是个标识,我们重点关注其概念: 概念: ...