[考试总结]noip模拟33
连炸两场。。。
伤心。。。
第一个题目首先因为有期望坐镇,然后跳过。。。
然后第二个题目发现题目挺绕的,然后转化了一句话题意,然后。。。。。
\(\huge{\text{转化错了!!!!}}\)
然而。。。
\(\huge{\text{样例过了!!!}}\)
什么玩意!!!!!
然后就有 \(9pts\) 。。。
然后 \(T3\) 打了一个自己都觉得假的最大生成树。
然后完全图还没有判断正确,导致。。。。
只有 \(10pts\)
如果再这样就真的要被翻了。。。。
Hunter
又是一个结论题。
其实这个看到题解之后完全不用懊悔
这个是真的不太好推出来。
虽然思路很简单。
答案就是:
\]
然后就三行代码。。。。
#include<bits/stdc++.h>
typedef long long ll;const ll mod = 998244353; ll n,w[1000001],ans = 1;inline ll ksm(ll x,ll y) {register ll ret = 1; while(y) {if(y & 1) ret = ret * x % mod;x = x * x % mod; y >>= 1;} return ret;}
signed main() {std::cin >> n >> w[1]; for(ll i=2;i<=n;++i) std::cin >> w[i],(ans += w[i] * ksm(w[1] + w[i],mod-2) % mod) %= mod; std::cout<<ans;}
真不骗你,就三行。
Defence
这个题目的意思并不是要让你求 \(0\) 的个数!!!!
而是求最长的连续 \(0\) 的个数。。。。
然后显然发现可以线段树合并。。。。
跟板子一样。。。。
水得一批。。。。
#include<bits/stdc++.h>
using std::cout; using std::endl;
#define try(i,a,b) for(register signed i=a;i<=b;++i)
#define throw(i,a,b) for(register signed i=a;i>=b;--i)
#define asm(i,x) for(register signed i=head[x];i;i=edge[i].next)
namespace xin_io
{
#define debug cout<<"debug"<<endl
#define enum(x) cout<<#x" = "<<x<<endl;
#define gc() p1 == p2 and (p2 = (p1 = buf) + fread(buf,1,1<<20,stdin),p1 == p2) ? EOF : *p1++
char buf[1<<20],*p1 = buf,*p2 = buf; int ak; typedef long long ll; typedef unsigned long long ull;
class xin_stream{public:template<typename type>inline xin_stream &operator >> (type &x)
{
register type s = 0; register int f = 1; register char ch = gc();
while(!isdigit(ch)) {if(ch == '-') f = -1; ch = gc();}
while( isdigit(ch)) s = (s << 1) + (s << 3) + (ch xor 48),ch = gc(); return x = s * f,*this;
}}io;
}
using namespace xin_io; static const int maxn = 1e5+10,inf = 1e9+7,mod = 998244353; const ll llinf = 1e18+7;
namespace xin
{
class xin_edge{public:int next,ver;}edge[maxn];
int head[maxn],zhi = 0;
inline void add(int x,int y) {edge[++zhi].ver = y; edge[zhi].next = head[x]; head[x] = zhi;}
int root[maxn],tot;
class xin_segment
{
private:
#define ls(fa) (t[fa].lson)
#define rs(fa) (t[fa].rson)
inline void up(int fa)
{
t[fa].size = t[ls(fa)].size + t[rs(fa)].size;
t[fa].s = std::max(t[ls(fa)].s , t[rs(fa)].s);
if(t[rs(fa)].lpos and t[ls(fa)].rpos) t[fa].s = std::max(t[fa].s,t[rs(fa)].lpos - t[ls(fa)].rpos - 1);
if(!t[rs(fa)].rpos) t[fa].rpos = t[ls(fa)].rpos; else t[fa].rpos = t[rs(fa)].rpos;
if(!t[ls(fa)].lpos) t[fa].lpos = t[rs(fa)].lpos; else t[fa].lpos = t[ls(fa)].lpos;
}
public:
class xin_tree{public:int s,lson,rson,lpos,rpos,size;}t[maxn * 32];
void insert(int &fa,int l,int r,int pos)
{
if(!fa) fa = ++tot;
if(l == r) {t[fa].lpos = t[fa].rpos = l; t[fa].size = 1; return ;}
register int mid = l + r >> 1;
if(pos <= mid) insert(ls(fa),l,mid,pos); else insert(rs(fa),mid+1,r,pos);
up(fa);
}
int merge(int x,int y,int l,int r)
{
if(!x or !y) return x | y;
if(l == r) return x;
register int mid = l + r >> 1;
ls(x) = merge(ls(x),ls(y),l,mid); rs(x) = merge(rs(x),rs(y),mid+1,r);
up(x);
return x;
}
}t;
int n,m,qnum;
int ans[maxn];
void dfs(int x)
{
asm(i,x)
{
register int y = edge[i].ver;
dfs(y);
root[x] = t.merge(root[x],root[y],1,m);
}
if(!t.t[root[x]].size) ans[x] = -1;
else ans[x] = std::max(t.t[root[x]].s,t.t[root[x]].lpos - 1 + m - t.t[root[x]].rpos);
}
inline short main()
{
io >> n >> m >> qnum;
try(i,1,n-1)
{
register int x,y; io >> x >> y;
add(x,y);
}
try(i,1,qnum)
{
register int x,y; io >> x >> y;
t.insert(root[x],1,m,y);
}
dfs(1);
try(i,1,n) printf("%d\n",ans[i]);
return 0;
}
}
signed main() {return xin::main();}
Connect
这个题目给人的第一直觉就是求一个最大生成树,然后用总价减去
然后是假的,并且你可以过样例。
然后 \(10pts\) 收场。。。。
我们可以考虑状压,因为发现这个 \(n\) 的范围很小很小。
然后枚举补集的子集,很好转移。。
%: pragma GCC optimize("O3","Ofast","inline")
#include<bits/stdc++.h>
using std::cout; using std::endl;
#define try(i,a,b) for(register signed i=a;i<=b;++i)
#define throw(i,a,b) for(register signed i=a;i>=b;--i)
#define asm(i,x) for(register signed i=head[x];i;i=edge[i].next)
namespace xin_io
{
#define debug cout<<"debug"<<endl
#define enum(x) cout<<#x" = "<<x<<endl;
#define gc() p1 == p2 and (p2 = (p1 = buf) + fread(buf,1,1<<20,stdin),p1 == p2) ? EOF : *p1++
char buf[1<<20],*p1 = buf,*p2 = buf; int ak; typedef long long ll; typedef unsigned long long ull;
class xin_stream{public:template<typename type>inline xin_stream &operator >> (type &x)
{
register type s = 0; register int f = 1; register char ch = gc();
while(!isdigit(ch)) {if(ch == '-') f = -1; ch = gc();}
while( isdigit(ch)) s = (s << 1) + (s << 3) + (ch xor 48),ch = gc(); return x = s * f,*this;
}}io;
}
using namespace xin_io; static const int maxn = 15,inf = 1e9+7,mod = 998244353; const ll llinf = 1e18+7;
namespace xin
{
int sum[1<<maxn],dis[maxn][maxn];
int n,m;
int f[1<<maxn][maxn];
inline short main()
{
io >> n >> m;
try(i,1,m)
{
register int x,y,z; io >> x >> y >> z;
dis[x-1][y-1] = dis[y-1][x-1] = z;
}
try(i,1,(1 << n) - 1)try(j,0,n-1)try(k,j+1,n-1)
if(((i >> j) & 1) and ((i >> k) & 1))
sum[i] += dis[j][k];
memset(f,-0x3f,sizeof (f));
// try(i,0,(1<<maxn)-1) try(j,0,maxn-1) f[i][j] = -inf;
f[1][0] = 0;
try(i,1,(1 << n) - 1)
try(j,0,n - 1)
{
if(f[i][j] == -1044266559) continue;
try(k,0,n - 1)if(dis[j][k] and !((1 << k) & i)) f[i | (1 << k)][k] = std::max(f[i | (1 << k)][k],f[i][j] + dis[j][k]);
register int jihe = (i xor ((1 << n) - 1));
for(register int k=jihe;k;k=(k-1)&jihe) f[i|k][j] = std::max(f[i|k][j],f[i][j] + sum[k|(1<<j)]);
}
printf("%d\n",sum[(1<<n)-1] - f[(1 << n) - 1][n-1]);
return 0;
}
}
signed main() {return xin::main();}
[考试总结]noip模拟33的更多相关文章
- 2021.8.8考试总结[NOIP模拟33]
T1 Hunter 考场上一看期望直接状压拿了$45pts$跑了.结果正解只用$4$行? 把问题转化为一号猎人之前死的猎人数的期望加一. 期望的线性性. 对每个猎人$i$,$w_i+w_1$种情况中有 ...
- 8.8考试总结(NOIP模拟33)[Hunter·Defence·Connect]
无法逃避的是自我,而无法挽回的是过去. 前言 还算可以,不过 T1 少 \(\bmod\) 了一下挂了 25pts,T2 没看清题面挂了 27pts. 下回注意吧.. T1 Hunter 解题思路 感 ...
- noip模拟33[进阶啦啦啦]
noip模拟33 solutions 不知道该咋说,这场考试其实是我这三四场以来最最最最最顺心的一场了 为啥呢?因为我这回思考有很多结果,得到了脑袋的回复 就是你想了半个小时就有了一点点头绪,那感觉就 ...
- noip模拟33
\(\color{white}{\mathbb{失足而坠千里,翻覆而没百足,名之以:深渊}}\) 这场考试的时间分配非常不科学 开题试图想 \(t1\) 正解,一个半小时后还是只有暴力,特别惊慌失措 ...
- 6.17考试总结(NOIP模拟8)[星际旅行·砍树·超级树·求和]
6.17考试总结(NOIP模拟8) 背景 考得不咋样,有一个非常遗憾的地方:最后一题少取膜了,\(100pts->40pts\),改了这么多年的错还是头一回看见以下的情景... T1星际旅行 前 ...
- 5.23考试总结(NOIP模拟2)
5.23考试总结(NOIP模拟2) 洛谷题单 看第一题第一眼,不好打呀;看第一题样例又一眼,诶,我直接一手小阶乘走人 然后就急忙去干T2T3了 后来考完一看,只有\(T1\)骗到了\(15pts\)[ ...
- 5.22考试总结(NOIP模拟1)
5.22考试总结(NOIP模拟1) 改题记录 T1 序列 题解 暴力思路很好想,分数也很好想\(QAQ\) (反正我只拿了5pts) 正解的话: 先用欧拉筛把1-n的素数筛出来 void get_Pr ...
- 2021.9.17考试总结[NOIP模拟55]
有的考试表面上自称NOIP模拟,背地里却是绍兴一中NOI模拟 吓得我直接文件打错 T1 Skip 设状态$f_i$为最后一次选$i$在$i$时的最优解.有$f_i=max_{j<i}[f_j+a ...
- [考试总结]noip模拟23
因为考试过多,所以学校的博客就暂时咕掉了,放到家里来写 不过话说,vscode的markdown编辑器还是真的很好用 先把 \(noip\) 模拟 \(23\) 的总结写了吧.. 俗话说:" ...
随机推荐
- Java安全之反序列化回显研究
Java安全之反序列化回显研究 0x00 前言 续上文反序列化回显与内存马,继续来看看反序列化回显的方式.上篇文中其实是利用中间件中存储的Request 和Response对象来进行回显.但并不止这么 ...
- 百炼3752:走迷宫--栈实现dfs
3752:走迷宫 总时间限制: 1000ms 内存限制: 65536kB 描述 一个迷宫由R行C列格子组成,有的格子里有障碍物,不能走:有的格子是空地,可以走.给定一个迷宫,求从左上角走到右下角最 ...
- ECMAScript 2021 正式确认
ECMAScript 2021 主要包含内容: ECMAScript 2021 于2021年6月22日获得 ECMA International 的批准.ECMAScript 是标准化的 JavaSc ...
- 乘风破浪,.Net Core遇见MAUI(.NET Multi-platform App UI),进击现代化跨设备应用框架
什么是MAUI https://github.com/dotnet/maui .NET Multi-platform App UI (MAUI) 的前身是Xamarin.Forms(适用于Androi ...
- hive学习笔记之十:用户自定义聚合函数(UDAF)
欢迎访问我的GitHub 这里分类和汇总了欣宸的全部原创(含配套源码):https://github.com/zq2599/blog_demos 本篇概览 本文是<hive学习笔记>的第十 ...
- hugegraph 源码解读 —— 索引与查询优化分析
为什么要有索引 gremlin 其实是一个逐级过滤的运行机制,比如下面的一个简单的gremlin查询语句: g.V().hasLabel("label").has("pr ...
- Docker:Centos7更新yum源下载docker
前言: Docker 要求 CentOS 系统(6.5及以上)的内核版本高于 3.10 ,查看本页面的前提条件来验证你的CentOS 版本是否支持 Docker . 通过 uname -r 命令查看你 ...
- edraw max for mac 安装
1.下载网址:https://xclient.info/s/edraw-max.html#versions 2.安装断网安装,直接打开 .dmg文件安装 3.按照阅读文件中的第二步,将opt.cell ...
- Git submodule 拉取子模块
$ git clone https://code.Xcode.com.client.git Cloning into 'vipkid-pc-client'... Username for 'https ...
- python 06篇 常用模块
一.模块 什么是模块? 模块实质上就是一个python文件,它是用来组织代码的,意思就是说把python代码写到里面,文件名就是模块的名称,test.py test就是模块名称. 1.1 导入模块 i ...