LOJ#2977. 「THUSCH 2017」巧克力(斯坦纳树+随机化)
题目
做法
- 考虑部分数据(颜色较少)的:
二分中位数\(mid\),将\(v[i]=1000+(v[i]>mid)\)
具体二分操作:然后求出包含\(K\)种颜色的联通快最小的权值和,判断该权值和是否满足中位数为\(mid\),从而调整范围
其中求权值和显然可以用斯坦纳树解决
- 正解:
我们每次随机把颜色映射到\([0,K)\)中去,每次得到的结果正确率就为答案联通块的离散颜色正好一一对应的概率:\(\frac{K!}{K^K}\)
随机\(233\)次,有\(99\%\)以上的正确率
Code
#include<bits/stdc++.h>
#include<queue>
typedef int LL;
const LL dx[]={0,-1,0,1,0},dy[]={0,0,1,0,-1};
const LL maxn=7e4+9,inf=1e8;
inline LL Read(){
LL x=0,f=1; char c=getchar();
while(c<'0'||c>'9'){
if(c=='-') f=-1; c=getchar();
}
while(c>='0'&&c<='9'){
x=(x<<3)+(x<<1)+c-'0',c=getchar();
}
return x*f;
}
std::queue<LL> que;
LL n,m,T,K,C,tot;
LL f[maxn][109],c[maxn],sta[maxn],d[maxn][2],a[maxn],pos[255][255],v[maxn],hs[maxn];
inline bool Ok(LL x,LL y){
return x>=1 && x<=n && y>=1 && y<=m;
}
inline void Spfa(LL bit){
for(LL i=1;i<=tot;++i) if(c[i]!=-1) que.push(i);
while(que.size()){
LL now(que.front()); que.pop();
LL x(d[now][0]),y(d[now][1]);
for(LL i=1;i<=4;++i){
LL xx(x+dx[i]),yy(y+dy[i]),to(pos[xx][yy]);
if(!Ok(xx,yy) || c[to]==-1) continue;
if(f[to][bit]>f[now][bit]+a[to]){
f[to][bit]=f[now][bit]+a[to];
que.push(to);
}
}
}
}
inline LL Solve(LL up){
for(LL i=0;i<up;++i)
for(LL j=1;j<=tot;++j)
f[j][i]=inf;
for(LL i=1;i<=tot;++i) if(c[sta[i]]!=-1) f[i][1<<hs[c[i]]]=a[i];
for(LL bit=1;bit<up;++bit){
for(LL i=1;i<=tot;++i){
LL x(i);
if(c[x]==-1) continue;
for(LL bit1=(bit-1)&bit;bit1;bit1=(bit1-1)&bit)
f[x][bit]=std::min(f[x][bit],f[x][bit1]+f[x][bit-bit1]-a[x]);
}
Spfa(bit);
}
LL ans(inf);
for(LL i=1;i<=tot;++i) ans=std::min(ans,f[i][up-1]);
return ans;
}
int main(){
srand(time(NULL));
T=Read();
while(T--){
n=Read(); m=Read(); K=Read(); tot=0;
sta[0]=0;
C=0;
for(LL i=1;i<=n;++i)
for(LL j=1;j<=m;++j){
pos[i][j]=++tot;
d[tot][0]=i; d[tot][1]=j;
}
for(LL i=1,now=0;i<=n;++i)
for(LL j=1;j<=m;++j){
LL col(Read());
c[++now]=col;//col
C=std::max(C,col);
}
for(LL i=1,now=0;i<=n;++i)
for(LL j=1;j<=m;++j)
v[++now]=Read();//val
LL up(1<<K),ans1(inf),ans2(inf);
for(LL i=1;i<=233;++i){
for(LL j=1;j<=C;++j) hs[j]=rand()%K;
LL l(0),r(1000000),a1(inf),a2(inf);
while(l<=r){
LL mid(l+r>>1);
for(LL i=1;i<=tot;++i) a[i]=(c[i]==-1?inf:1000+(v[i]>mid));
LL now(Solve(up));
if(now==inf) break;
a1=now/1000;
LL small(a1-(now-a1*1000));
if(small>=(a1+1>>1)){
a2=mid; r=mid-1;
}else l=mid+1;
}
if(a1<ans1 || (a1==ans1 && a2<ans2)){
ans1=a1; ans2=a2;
}
}
if(ans1==-1) puts("-1 -1");
else printf("%d %d\n",ans1,ans2);
}
return 0;
}
LOJ#2977. 「THUSCH 2017」巧克力(斯坦纳树+随机化)的更多相关文章
- @loj - 2977@ 「THUSCH 2017」巧克力
目录 @description@ @solution@ @accepted code@ @details@ @description@ 「人生就像一盒巧克力,你永远不知道吃到的下一块是什么味道.」 明 ...
- LOJ 2997 「THUSCH 2017」巧克力——思路+随机化+斯坦纳树
题目:https://loj.ac/problem/2977 想到斯坦纳树.但以为只能做 “包含一些点” 而不是 “包含一些颜色” .而且不太会处理中位数. 其实 “包含一些颜色” 用斯坦纳树做也和普 ...
- LOJ 2980 「THUSCH 2017」大魔法师——线段树
题目:https://loj.ac/problem/2980 线段树维护矩阵. 然后是 30 分.似乎是被卡常了?…… #include<cstdio> #include<cstri ...
- loj2977 巧克力 (斯坦纳树+随机化)
考虑颜色比较少的时候,第一问可以直接斯坦纳树 第二问考虑二分,每次把每格的权值给成1000+[a[i]>m],就是在个数最少的基础上尽量选小于等于m的 然而颜色太多不能直接做,但可以把每种颜色映 ...
- LOJ #2978「THUSCH 2017」杜老师
听说LOJ传了THUSC题赶紧上去看一波 随便点了一题都不会做想了好久才会写暴力爆了一发过了... LOJ #2978 题意 $ T$次询问,每次询问$ L,R$,问有多少种选取区间中数的方案使得选出 ...
- LOJ 2979 「THUSCH 2017」换桌——多路增广费用流
题目:https://loj.ac/problem/2979 原来的思路: 优化连边.一看就是同一个桌子相邻座位之间连边.相邻桌子对应座位之间连边. 每个座位向它所属的桌子连边.然后每个人建一个点,向 ...
- LOJ 2978 「THUSCH 2017」杜老师——bitset+线性基+结论
题目:https://loj.ac/problem/2978 题解:https://www.cnblogs.com/Paul-Guderian/p/10248782.html 第 i 个数的 bits ...
- loj#2978. 「THUSCH 2017」杜老师(乱搞)
题面 传送门 题解 感谢yx巨巨 如果一个数是完全平方数,那么它的所有质因子个数都是偶数 我们把每一个数分别维护它的每一个质因子的奇偶性,那么就是要我们选出若干个数使得所有质因子的个数为偶数.如果用线 ...
- 「THUSCH 2017」大魔法师 解题报告
「THUSCH 2017」大魔法师 狗体面太长,帖链接了 思路,维护一个\(1\times 4\)的答案向量表示\(A,B,C,len\),最后一个表示线段树上区间长度,然后每次的操作都有一个转移矩阵 ...
随机推荐
- Vue+VSCode开发环境搭建
时间2019.9月 1. 安装 nodeJS; 安装VScode 安装好nodeJS之后,默认会安装好npm 测试 nodeJS 和npm是否可以执行 node -v npm -v 1.1 VScod ...
- SQL SERVER 中如何获取日期(一个月的最后一日、一年的第一日等等)
https://blog.csdn.net/deepwishly/article/details/9101307 这是计算一个月第一天的SQL 脚本: SELECT DATEADD(mm, DAT ...
- C# 阿拉伯数字转换为中文数字/中文数字转换为阿拉伯数字
项目中经常会格式化数据,转换数字的使用情况比较多,记录一下数字转换的方法! 如果需要转换为繁体中文,将数组里的汉字换成繁体中文即可. 1.阿拉伯数字转换为中文数字 /// <summary> ...
- PIE二次开发——大气校正
窗体设计: 代码: private void button_src_Click(object sender, EventArgs e) { OpenFileDialog openFile = new ...
- 关于utf8mb4的使用
针对mysql数据库存储一些特殊字符或者emoji的字符,所需要的编码类型.实际上基于efcore框架的情况下,codefirst自动迁移生成的数据库的默认编码格式,就是utf8mb4,以前的时候记得 ...
- 前端开发 Vue -4promise解读2
https://www.runoob.com/vue2/vue-tutorial.html promise promise是什么? 1.主要用于异步计算 2.可以将异步操作队列化,按照期望的顺序执 ...
- 如何实现高性能的IO及其原理?
程序运行在内存以及IO的体现 首先普及一下常识,如图所示: 1.在整个内存空间中,跑着各种各样的程序,有Java程序.C程序,他们共用一块内存空间. 2.对于Java程序,JVM会申请一块堆空间,通过 ...
- c# 属性成员
- 【视频】谷歌大佬30分钟让你入门机器学习(2019谷歌I/O资源分享)
如果你是个谷粉,就一定会知道: 谷歌向来都很大胆.当所有的科技公司都在讲产品.讲利润的时候,2019年的谷歌开发者大会的主题却是:人文关怀.要知道,这是政府操心的事,而不是一家公司的任务. 谷歌敢这样 ...
- 《Hello--world团队》第三次作业:团队项目的原型设计
项目 内容 这个作业属于哪个课程 2016级计算机科学与工程学院软件工程(西北师范大学) 这个作业的要求在哪里 实验七 团队作业3:团队项目原型设计与开发 团队名称 <hello--world团 ...