6.14 YZBOI模拟赛solution
\(6.14\ YZBOI\)模拟赛\(solution\)
本来不想写题解来着。。。毕竟是自己找的题还是写一写吧
上午为了整活,就把赛制改成\(IOI\)赛制了,于是乎拯救了大家的\(70pts\)代码。
三道巨水的题。。。\(bz\)迅速就\(AK\)了。。。
\(T1\ Delta\)
比较直观的想,肯定是找一个少的的完全图划分了,又发现平方具有传递性,就变成维护联通块了
#include<bits/stdc++.h>
#define int long long
#define MAXN 5005
using namespace std;
int n,a[MAXN],fa[MAXN],ans[MAXN];
bool vis[MAXN];
int Find(int x)
{
if(fa[x]==x) return x;
return fa[x]=Find(fa[x]);
}
signed main()
{
scanf("%lld",&n);
for(int i=1;i<=n;i++)
{
fa[i]=i;
scanf("%lld",&a[i]);
}
for(int i=1;i<=n;i++)
{
for(int j=i+1;j<=n;j++)
{
if(a[i]*a[j]>0)
{
if((int)sqrt(a[i]*a[j])*(int)sqrt(a[i]*a[j])!=a[i]*a[j]) continue;
int fi=Find(i);
int fj=Find(j);
if(fi==fj) continue;
fa[fi]=fj;
}
}
}
for(int i=1;i<=n;i++)
{
memset(vis,0,sizeof(vis));
int num=0;
for(int j=i;j<=n;j++)
{
if(a[j]!=0&&vis[Find(j)]==false)
{
vis[Find(j)]=true;
num++;
}
if(num==0) ans[num+1]++;
else ans[num]++;
}
}
for(int i=1;i<=n;i++)
{
cout<<ans[i]<<" ";
}
}
\(T2 Add\)
线性规划会吧,模拟会吧,单纯形法会吧,转对偶会吧,那么这就是一道水题了
#include <bits/stdc++.h>
using namespace std;
#define MAXN 100005
const double eps=1e-9;
const int INF=1000000000;
double a[1005][MAXN],b[MAXN],v,c[MAXN];
int m,n;
void solve(int l,int e)
{
b[l]/=a[l][e];
for(int i=1;i<=n;++i) if(i!=e) a[l][i]/=a[l][e];
a[l][e]=1/a[l][e];
for(int i=1;i<=m;++i)
{
if(i!=l&&abs(a[i][e])>eps)
{
b[i]-=b[l]*a[i][e];
for(int j=1;j<=n;++j)
{
if(j!=e) a[i][j]-=a[l][j]*a[i][e];
}
a[i][e]=-a[i][e]*a[l][e];
}
}
v+=c[e]*b[l];
for(int i=1;i<=n;++i)
{
if(i!=e) c[i]-=c[e]*a[l][i];
}
c[e]=-c[e]*a[l][e];
}
void simplex()
{
int l,e;
while(true)
{
for(e=1;e<=n;++e)
{
if(c[e]>eps) break;
}
if(e>n) break;
double t=INF;
for(int i=1;i<=m;++i)
{
if(a[i][e]>eps&&b[i]/a[i][e]<t)
{
l=i;
t=b[i]/a[i][e];
}
}
solve(l,e);
}
}
int main()
{
//关于转对偶
//n,m交换
//把b(限制的和)变成c(系数),把c变成b
//把矩阵a转置
//然后单纯形求一个最小即可
cin>>m>>n;
for(int i=1;i<=m;++i) scanf("%lf",&b[i]);
for(int i=1,l,r;i<=n;++i)
{
scanf("%d%d",&l,&r);
for(int j=l;j<=r;++j) ++a[j][i];
scanf("%lf",&c[i]);
}
simplex();
printf("%.0lf\n",v);
return 0;
}
\(T3\ Times\)
我记得这道题是我省选前一天为了帮忙\(debug\)写的
考虑最优解必然是在最小生成树上的,然后考虑从大往小删除边,我们需要保证删边之后每个联通块至少有一个守卫,那么大概就是我们对每个守卫匹配一个边去割掉,而且不存在交叉,那么就可以很直观的用费用流来表示
#include<bits/stdc++.h>
#define MIN 0xcfcfcfcfcfcfcfcf
#define INF 2147483647
#define int long long
#define MAXN 1000005
using namespace std;
struct node
{
int u,v,w;
}lu[MAXN];
int head[MAXN],cost[MAXN],val[MAXN],nxt[MAXN],to[MAXN],tot=1;
int dis[MAXN],fa[MAXN],Sum,s,t,n,m,k;
bool vis[MAXN],in[MAXN];
vector<pair<int,int> >rd[MAXN];
int Find(int x)
{
if(fa[x]==x) return x;
return fa[x]=Find(fa[x]);
}
int R(int x)
{
return x+n+n;
}
int ru(int x)
{
return x;
}
int chu(int x)
{
return x+n;
}
void add(int u,int v,int w,int cts)
{
tot++; to[tot]=v; val[tot]=w; cost[tot]=cts; nxt[tot]=head[u]; head[u]=tot;
swap(u,v),w=0,cts*=-1;
tot++; to[tot]=v; val[tot]=w; cost[tot]=cts; nxt[tot]=head[u]; head[u]=tot;
}
bool bfs(int s,int t)
{
memset(dis,0xcf,sizeof(dis));
queue<int>q;
dis[s]=0;
in[s]=true;
q.push(s);
while(q.size())
{
int now=q.front();
q.pop();
in[now]=false;
for(int i=head[now];i;i=nxt[i])
{
int y=to[i];
if(val[i]&&dis[y]<dis[now]+cost[i])
{
dis[y]=dis[now]+cost[i];
if(!in[y]) in[y]=true,q.push(y);
}
}
}
// cout<<"dis: "<<dis[t]<<"\n";
return dis[t]!=MIN;
}
int dfs(int now,int ed,int flow)
{
if(now==ed) return flow;
vis[now]=true;
int rest=flow;
for(int i=head[now];i&&rest;i=nxt[i])
{
int y=to[i];
if(dis[y]!=dis[now]+cost[i]||!val[i]||vis[y]) continue;
int k=dfs(y,ed,min(val[i],rest));
val[i]-=k;
val[i^1]+=k;
rest-=k;
if(!k) dis[y]=INF;
}
vis[now]=false;
return flow-rest;
}
void dfs_tree(int now,int pre,int Cst)
{
if(pre)add(chu(now),ru(pre),1,0);
add(chu(now),t,1,Cst);
for(int i=0;i<rd[now].size();i++)
{
int y=rd[now][i].first;
if(y==pre) continue;
dfs_tree(y,now,rd[now][i].second);
}
}
bool cmp(node a,node b)
{
return a.w<b.w;
}
signed main()
{
scanf("%lld%lld%lld",&n,&m,&k);
for(int i=1;i<=m;i++)
{
scanf("%lld%lld%lld",&lu[i].u,&lu[i].v,&lu[i].w);
}
sort(lu+1,lu+1+m,cmp);
for(int i=1;i<=n;i++) fa[i]=i;
for(int i=1;i<=m;i++)
{
int fu=Find(lu[i].u);
int fv=Find(lu[i].v);
if(fu!=fv)
{
fa[fu]=fv;
rd[fu].push_back(make_pair(fv,lu[i].w));
rd[fv].push_back(make_pair(fu,lu[i].w));
// cout<<"add: "<<fu<<" "<<fv<<" "<<lu[i].w<<"\n";
Sum+=lu[i].w;
}
}
s=n+n+k+1;
t=n+n+k+2;
for(int i=1,num;i<=k;i++)
{
add(s,R(i),1,0);
scanf("%lld",&num);
for(int j=1,cun;j<=num;j++)
{
scanf("%lld",&cun);
add(R(i),ru(cun),1,0);
}
}
for(int i=1;i<=n;i++)
{
add(ru(i),chu(i),1,0);
}
for(int i=1;i<=n;i++)
{
if(Find(i)==i)
{
Sum+=INF;
dfs_tree(i,t,INF);
}
}
int z=0;
while(bfs(s,t))
{
int v=dfs(s,t,INF);
z+=v;
Sum-=v*dis[t];
}
if(z!=k)
{
cout<<-1;
return 0;
}
if(Sum>=INF)
{
cout<<-1;
return 0;
}
cout<<Sum<<"\n";
}
6.14 YZBOI模拟赛solution的更多相关文章
- 2019.03.14 ZJOI2019模拟赛 解题报告
得分: \(100+100+0=200\)(\(T1\)在最后\(2\)分钟写了出来,\(T2\)在最后\(10\)分钟写了出来,反而\(T3\)写了\(4\)个小时爆\(0\)) \(T1\):风王 ...
- 【2019.8.14 慈溪模拟赛 T1】我不是!我没有!别瞎说啊!(notme)(BFS+DP)
\(IDA^*\) 说实话,这道题我一开始没想出正解,于是写了一个\(IDA^*\)... 但神奇的是,这个\(IDA^*\)居然连字符串长度分别为\(2500,4000\)的数据都跑得飞快,不过数据 ...
- 【2019.8.14 慈溪模拟赛 T2】黑心老板(gamble)(2-SAT)
\(2-SAT\) 考虑每个点只能选择\(R\)或\(B\),可以看作选\(0\)或\(1\). 然后对于给出的关系式,若其中一个位置满足关系式,另两个位置就必须不满足关系式,这样就可以对于每个关系式 ...
- PAT团体程序设计天梯赛 - 模拟赛
由于本人愚笨,最后一题实在无力AC,于是只有前14题的题解Orz 总的来说,这次模拟赛的题目不算难,前14题基本上一眼就有思路,但是某些题写起来确实不太容易,编码复杂度有点高~ L1-1 N个数求和 ...
- NOIP模拟赛 by hzwer
2015年10月04日NOIP模拟赛 by hzwer (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...
- PKUSC 模拟赛 day1 下午总结
下午到了机房之后又困又饿,还要被强行摁着看英文题,简直差评 第一题是NOIP模拟赛的原题,随便模拟就好啦 本人模拟功力太渣不小心打错了个变量,居然调了40多分钟QAQ #include<cstd ...
- [GRYZ]寒假模拟赛
写在前面 这是首次广饶一中的OIERS自编自导,自出自做(zuo)的模拟赛. 鉴于水平气压比较低,机(wei)智(suo)的WMY/XYD/HYXZC就上网FQ下海找了不少水(fei)题,经过他们优( ...
- GDOI模拟赛Round 1
GDOI模拟赛Round 1 数据结构 题目描述:给出一个长度为\(n\)的序列,支持两种操作: 1.对某段区间都加上一个数 2.给出\(p.k\),求下面表示式对\((10^9+7)\)取模 \[\ ...
- 3.27模拟赛 sutoringu(后缀数组)
\(\color{white}{mjt是机房模拟赛独自切过题的唯一的人...}\) (应本人要求删掉惹) \(Description\) 给你\(n,k\)和长为\(n\)的字符串\(s\).一个区间 ...
随机推荐
- 152. Maximum Product Subarray - LeetCode
Question 152. Maximum Product Subarray Solution 题目大意:求数列中连续子序列的最大连乘积 思路:动态规划实现,现在动态规划理解的还不透,照着公式往上套的 ...
- 关于我学git这档子事(2)
将本地main分支push到远程dev分支(不同名分支间的push) 远程dev分支还未创建 (在push同时创建远程dev分支,并将本地main分支内容上传) git push -u --set-u ...
- C++调用C#的动态库dll
以往我们经常是需要使用C#来调用C++的dll,这通过PInvoke就能实现.现在在实际的项目过程中,有时会遇到在C++的项目中调用某个C#的dll来完成特定的某个功能,我们都知道,Native C+ ...
- Sublime text eslint windows 配置
1. 下载安装eslint npm install -g eslint 2. 设置环境变量 C:\Users\<你的用户名>\AppData\Roaming\npm 3. sublime ...
- BUUCTF-[BJDCTF2020]认真你就输了
[BJDCTF2020]认真你就输了 下载通过16进制查看发现是压缩包,直接就binwalk分离查看. 分离直接得到几个文件,不过好像压缩包里的和外面的文件是一样的,所以直接翻一下目录 直接就找到了 ...
- 6G显卡显存不足出现CUDA Error:out of memory解决办法
从6月初开始,6G显存的显卡开始出现CUDA Error:out of memory的问题,这是因为dag文件一直在增加,不过要增加到6G还需要最少两年的时间. 现在出现问题的原因是1.内核太古老 ...
- Web思维导图实现的技术点分析(附完整源码)
简介 思维导图是一种常见的表达发散性思维的有效工具,市面上有非常多的工具可以用来画思维导图,有免费的也有收费的,此外也有一些可以用来帮助快速实现的JavaScript类库,如:jsMind.KityM ...
- 抓到 Netty 一个 Bug,顺带来透彻地聊一下 Netty 是如何高效接收网络连接的
本系列Netty源码解析文章基于 4.1.56.Final版本 对于一个高性能网络通讯框架来说,最最重要也是最核心的工作就是如何高效的接收客户端连接,这就好比我们开了一个饭店,那么迎接客人就是饭店最重 ...
- C#请求HTTPS地址的故障分析和TLS知识点总结
背景介绍 近期收到同事反馈,在C#程序中通过HTTPClient请求一个HTTPS的地址时,在本地开发环境和测试环境均能正常执行,而部署到生产环境后发生异常且稳定复现,异常提示为:[请求被中止: 未能 ...
- 记一道经典树上Nim游戏
这道题首先是 Hanriver 提出来的,但是大家都不会做,今天看到了一道一模一样的题目 AT2667 题目大意是,每个人删掉一个不是整棵树的原树的子树,给定一个树问游戏状态. 首先,这是需要用到多个 ...