10.27 CSP-S模拟40 改题记录

news/2025/10/27 21:29:54/文章来源:https://www.cnblogs.com/OrangeLand/p/19170226

HZOJ

写在前面

没想到离CSP还有4天然后创造了一次保龄的经历。。。然后就是读假题专场。其实感觉没有太难但是。。。好吧,碍于时间不多,也不说废话了。

A. 公约数神庙

我无言。我以为我败在了空间,结果其实是败给了糖错和可恶的特判。难得想出正解呜呜呜。题意是有一个数列,从编号小的到编号大的且公因数大于1的点对有有向边。给出询问一个点对是否能通达。

读假题,还说终于来签到题了。还好样例善良。肯定不考虑暴力建边,暴力转移也不可取。观察到\(i\) 可以通过中转点走到\(j\)。由于保证了从编号小的点走到编号大的点,我们考虑倒着维护通达性。观察到值域内每个数至多有4个质因数,共有168个质因数。由于从某个位置开始,就算一个数不含某个质因数也能通过中转点走到含有该质因子的位置,我们考虑维护每个质因数的数从哪个位置开始能走到另一个质因数的倍数上,动态加入取min即可。然后每个询问就枚举终点的质因数看其是否在起点可通达范围内即可。然后难点还没来,难点在特判。全场因为特判的问题挂了inf分。

B. 栈法师

读假题\(\times 2\)。甚至还写了1h。

题意是给出一个起始栈,构造一系列操作,使得栈内元素在终止栈内升序排列,且要求过渡栈的量最小。

省略读假题的内容。显然过渡栈的数量最多是2。考虑是1的情况,直接做看看能否满足要求即可。否则考虑先将所有元素放到一个过渡栈,这样每次操作都是有规律的不用特判。然后我们肯定要从小到大弹进终止栈,如果其上方有比其大的数肯定需要到过渡栈里待避,我们预处理出这个值即可。然后要弹出一个元素我们就先将其上方元素弹入另一个过渡栈,再将该元素弹出,再将过渡栈元素弹回去,就能减少分讨了。其实没有任何技术含量可言。

C. 城堡考古

改了inf小时没改完。先存下代码和题解。

由于 $m$ 很小,可以状压每一列的状态(1表示要伸到后一列),状态数为 $2^m=64$,$2^m =64$,列和列之间的转移可以用矩阵快速幂进行优化,注意:

需要写一个高精度的10->2进制转换(可以每次暴力做高精度除22,复杂度是对的),位数大概\(\times3\) 题目要求的是一个差分形式,需要矩阵多开一维记录前缀 sum直接实现的话大概能跑65分。

按照网格状压DP的套路,有很多状态其实是到不了的,dfs 预处理合法且能够从 s=0s=0 到达的状态,发现只有20个(其实是一个组合数,mm 列恰有 \(\binom{m}{m/2}\) 个合法状态)。

复杂度变为 \(O(20^3\times len)\),这样就能通过了。

#include<bits/stdc++.h>
using namespace std;
const int maxn=100,mod=998244353;
int dp[maxn][maxn];
string sl,sr;
bitset<10000> l,r;
int m;
struct matrix{int a[30][30];matrix(){memset(a,0,sizeof(a));}inline matrix operator*(const matrix &b)const{matrix c;for(int i=1;i<=m;i++){for(int k=1;k<=m;k++){int p=a[i][k];for(int j=1;j<=m;j++)c.a[i][j]=(c.a[i][j]+1ll*p*b.a[k][j]%mod)%mod;}}return c;}
}ll,rr,aa;
inline void qpow(matrix &a,matrix b,bitset<10000> y){for(int i=0;i<10000;i++){if(y[i]) a=a*b;b=b*b;}
}
inline string div(string &s){string ss="";int now=0;for(int i=0;i<s.size();i++){now=now*10+s[i]-'0';if(now==1&&i<s.size()-1) continue;ss+=now/2+'0';now%=2;}return ss; 
}
inline void get2(string &s,bitset<10000> &c){for(int i=0;;i++){if((s[s.size()-1]-'0')&1){c[i]=1;} s=div(s);if(s[0]=='0') break;}
}
bool vis[70];
inline void dfs(int las,int lv){vis[las]=1;if(lv>=5) return;for(int i=0;i<(1<<m);i++){bool flg=1;int cnt=0;for(int j=0;j<m;j++)if(((i>>j)&1)&&((las>>j)&1)){flg=0;break;}else if(((i>>j)&1)||((las>>j)&1)){if(cnt&1){flg=0;break;}cnt=0;}else ++cnt;if(cnt&1) flg=0;if(flg) dfs(i,lv+1);}
}
vector<int> legal;
bool start[70];
inline bool check(int x,int y){int cnt=0;for(int i=0;i<m;i++)if((((x>>i)&1)&&((y>>i)&1))) return 0;else if(((x>>i)&1)||((y>>i)&1)){if(cnt&1) return 0;cnt=0;}else ++cnt;if(cnt&1) return 0;	return 1;
}
int main(){freopen("decoration.in","r",stdin);freopen("decoration.out","w",stdout);ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);cin>>sl;cin>>sr;cin>>m;for(int i=sl.size()-1;i>=0;i--){sl[i]--;if(sl[i]>='0') break;sl[i]+=10;}if(sl[0]=='0'){string ss=sl;sl="";for(int i=1;i<ss.size();i++) sl+=ss[i];}int cnt=0;get2(sl,l);get2(sr,r);if(m==1) vis[0]=vis[1]=1,cnt=2;else{for(int i=0;i<(1<<m);i++){vis[i]=1;int cnt=0;for(int j=0;j<m;j++)if((i>>j)&1){if(cnt&1){vis[i]=0;break;}cnt=0;}else ++cnt;if(cnt&1) vis[i]=0;if(vis[i]) start[i]=1,dfs(i,0);}for(int i=0;i<(1<<m);i++)if(vis[i]){legal.emplace_back(i),++cnt;if(start[i]) ll.a[cnt][1]=rr.a[cnt][1]=1;} }for(int i=0;i<legal.size();i++)for(int j=0;j<legal.size();j++)if(check(legal[i],legal[j])) aa.a[i+1][j+1]=1;//,cout<<legal[i]<<' '<<legal[j]<<'\n';
//	ll=aa*ll;
//	cout<<ll.a[1][1]<<' '<<ll.a[2][2]<<'\n';qpow(ll,aa,l);qpow(rr,aa,r);int ans=0;for(int i=1;i<=cnt;i++) ans=(ans+rr.a[i][1])%mod;
//	cout<<ans<<'\n';for(int i=1;i<=cnt;i++) ans=(ans-ll.a[i][1])%mod;cout<<(ans%mod+mod)%mod;return 0;
}

D. 生命之树

感觉做过原题。然后咕了(其实是贺了题解式子然后自己懒得没空详写)。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/948101.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Codechef Painting Tree 题解 [ 蓝 ] [ 树形 DP ] [ 概率期望 ] [ 分类讨论 ]

Painting Tree 若干个月前模拟赛切的题,当时写了 3h+,被细节恶心坏了,遂记之。 题意可以转化为求树上存在相交链的期望时间。 考虑如何计算这个期望。显然我们可以枚举选取链的个数,根据期望的定义式来算: \[E(X)…

Linux运行命令三种方式对比

三种方式临时测试 → nohup 稳定运行 → supervisor 系统级守护 → systemd测试用例/data/test.sh #!/bin/bash # /data/test.sh - Linux 简单输出时间的 demo 脚本while true doecho "$(date +%Y-%m-%d %H:%M:%S…

P14322 「ALFR Round 11」E 空崎ヒナ 题解 (markdown)

P14322 「ALFR Round 11」E 空崎ヒナ 题解 (markdown)## P14322 「ALFR Round 11」E 空崎ヒナ 题解**Sorasaki Hina 赛高!**也是做上 BA 的题了!也是写上 BA 的题的题解了!我们 BA 厨的日子真是蒸蒸日上啊!求审核大…

详细介绍:论文阅读 (1) :Control Flow Management in Modern GPUs

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

公众号排版2025年权威推荐:揭秘有一云AI编辑器为何高效?

01|痛点雷区清单:为什么总被“排版”拖慢?层级乱:复制到后台后行距、间距、引用样式全乱,返工 ≥ 2 轮。 版式碎:字体、分隔、留白没节奏,读者滑两屏就流失。 配图难:素材东拼西凑、风格不统一,还担心侵权。 …

P14322 「ALFR Round 11」E 空崎ヒナ 题解

Sorasaki Hina 赛高!P14322 「ALFR Round 11」E 空崎ヒナ 题解 Sorasaki Hina 赛高! 也是做上 BA 的题了!也是写上 BA 的题的题解了!我们 BA 厨的日子真是蒸蒸日上啊! 求审核大大通过 QvQ。求求了! 题目描述:给…

[题解]P7074 [CSP-J 2020] 方格取数

P7074 [CSP-J 2020] 方格取数 如果设 \(f_{i,j}\) 为 \((1,1)\) 到 \((i,j)\) 的最大权值和,上下相邻的两个元素的转移就是双向的了。有后效性,无法 DP。不过题目说“不能重复经过已经走过的方格”,也就是说每一列只…

昨天线下赛的复盘

这次最大的感受:Re做题的时候不要啥都没分析出来就去写代码,不要觉得自己写着写着就能看懂,不可能的,不如先分析好,即使是先猜一下呢,还有就是测试数据不要写0,会和本身就是空的数据混了 Re1 分最少的一题,附件…

10 27

P11833因为我们有 \(a_i < a_{i+1}\) 且 \(b_i < b_{i+1}\) 这里我是想怎么样才能统计两两之间的影响,发现十分复杂并且是 \(O(N^2)\) 的也无法优化 然后我就发现时间限制的深意是否可以说是按照时间顺序从小到…

同余最短路学习报告

笑点解析:高一了终于知道同余最短路是什么了。谁家好人同余最短路真的写最短路啊同余最短路,一种题目类型,隶属于图论板块,一般是问你有 n 个值,重复选取能拼出多少值,或者拼出模 k 余 p 要多少个值等等等等。 对…

打包exe出错了:

打包exe出错了: Traceback (most recent call last): File "huu.py", line 6, in n = int(input(enter:)) RuntimeError: input(): lost sys.stdin 源码: python print(判断一个数是否为素数) print()whi…

19 lambda表达式的简化过程

19 lambda表达式的简化过程Lambda表达式 为什么引入lambda表达式?避免内部类定义过多 去掉无意义代码,只留下核心逻辑函数式接口 定义:任何借口,如果只包含唯一一个抽象方法,那么它就是一个函数式接口。 对于函数…

详细介绍:Redis多租户资源隔离方案:基于ACL的权限控制与管理

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

二分查找边界

二分查找边界二分查找边界Q:给定一个长度为𝑛的有序数组nums ,其中可能包含重复元素。请返回数组中最左一个元素target的索引。若数组中不包含该元素,则返回−1 。查找左边界 回忆二分查找插入点的方法,搜索完成…

求解 LCA 的三种方法及其比较

本文写于 2025 年 10 月 24 日。 昨天看到岁岁似今朝以“学不成名誓不还”的勇气学 LCA(树上最近公共祖先),并感叹“LCA 是我最严厉的母亲”,心血来潮,也学了一下。翻看着洛谷玲琅满目的题解,竟学会了三种方法,…

策略模式优化if-else

class Calculator:def __init__(self):self.strategy = Nonedef set_strategy(self, strategy):self.strategy = strategydef calculate_result(self, num1, num2):return self.strategy.execute(num1, num2)class Add…

捐赠

题目 题目描述 有 \(A\)、\(B\) 两类物品。 paper 打算每类各选 \(k\) 个(\(k\) 可自由决定,可取 \(0\))一起捐出。捐赠的总贡献为所选物品的价值总和。 初始时 paper 没有物品,但是 paper 可以通过一些操作改变物…

学习笔记:重链剖分

本文写于 2025 年 9 月 28 日。 前言 这几天一下课,班里的某位同学就走到我座位旁边,念叨着“来学树剖”。在他的 传销 诈骗 怂恿 鼓励之下,我也终于来到了这座大山面前,但发现似乎也并不难…… 何为重链剖分 考虑…

P3232 [HNOI2013] 游走

考虑贪心。 随机游走则显然每条边期望经过次数越大则其编号应越小。 每条边的期望经过次数难以计数,考虑每个店期望经过次数,设计状态 \(f_i\) 表示点 \(i\) 期望经过次数。 转移: \(f_i=\sum_{v\in e_i}f_v\cdot \…

FRP 后端无法获取请求者IP解决方案

FRP 后端无法获取请求者IP解决方案📝 FRP 后端无法获取请求者真实 IP?别慌,解决方案来啦!🧐 问题背景 当你使用 FRP 进行内网穿透或代理服务时,是否遇到过这样的困扰: 后端服务拿到的客户端 IP 全都是 FRP 服…