集训记录 1.7

集训记录 1.7

感觉最近效率好低啊。

打了几场省选模拟赛,几乎都垫底了。

主要是图论,贪心和博弈,其他的没怎么写,感觉DP以后有必要补,字符串和网络流暂时放一放。

【模板】最大流

EK和Dinic都学了,后者写的比较熟。

Dinic
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=5100;
const ll inf=1e16;
int n,m,s,t,a,b,c,depth[N];
ll ans;
bool vis[N];
struct graph{int cnt=1,head[N],nxt[N<<1],to[N<<1],now[N];ll val[N<<1];void add(int u,int v,int w){cnt++;to[cnt]=v;nxt[cnt]=head[u];val[cnt]=w;head[u]=cnt;}
}g;
queue<int>q;
bool bfs(){memset(depth,0,sizeof(int)*(n+1));memcpy(g.now,g.head,sizeof(int)*(n+1));while(!q.empty())q.pop();q.push(s);depth[s]=1;while(!q.empty()){int u=q.front();q.pop();for(int i=g.head[u];i;i=g.nxt[i]){if(!g.val[i])continue;int v=g.to[i];if(!depth[v]){depth[v]=depth[u]+1;q.push(v);if(v==t)return 1;}}}return 0;
}
ll dfs(int u,ll sum){if(u==t||sum==0)return sum;ll res=0,k=0;for(int i=g.now[u];i&&sum;i=g.nxt[i]){g.now[u]=i;int v=g.to[i];if(depth[v]==depth[u]+1){k=dfs(v,min(sum,g.val[i]));res+=k;sum-=k;g.val[i]-=k;g.val[i^1]+=k;}}return res;
}
signed main()
{// freopen("q.in","r",stdin);// freopen("q.out","w",stdout);scanf("%d%d%d%d",&n,&m,&s,&t);for(int i=1;i<=m;i++){scanf("%d%d%d",&a,&b,&c);g.add(a,b,c);g.add(b,a,0);}while(bfs()){ans+=dfs(s,inf);}cout<<ans;
}

墨墨的等式

学了学转圈法求同余最短路。发现每个物品的转移都形成环,在环上跑两圈转移即可。思路过于神奇,可能说不明白,具体实现看代码。

CODE
for(int i=1;i<=n;i++){int d=__gcd(a[i],a[1]);for(int j=0;j<d;j++){for(int k=j,c=1;c<=2;c+=(k==j)){int p=(k+a[i])%a[1];dp[p]=min(dp[p],dp[k]+a[i]);k=p;}}
}

Buy One, Get One Free

CF 3000*的反悔贪心。

有 $ n $ 个必须买的物品,支持如下买一赠一:对于一个全价购买的物品,可以赠送一个价格 严格小于 它的物品,求最小代价。

按照这样贪心:首先降序排序,将价格相同的物品合并,并记录个数。用堆维护赠送的物品价格。如果当前物品(设价格为 \(p\) )可以被赠送,则先入大根堆,对于这种物品不能赠送的部分,如果堆顶元素(设代价为 \(k\) )小于该物品,则反悔;否则,若 $ 2\times p>k $ 且该物品剩余数量不少于2,则将两个该物品和堆顶捆绑,看做一个新物品,代价为 $ 2\times p-k $ ,放入堆即可。发现这样可以反悔所有可能的情况,最后堆中的元素和就是优惠的价值。

CODE
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=5e5+100;
int n,a[N],lsh[N],sum[N],cnt,num[N],p[N],tot;
bool vis[N];
priority_queue<int,vector<int>,greater<int> >q;
ll ans;
stack<int>st;
signed main()
{// freopen("q.in","r",stdin);// freopen("q.out","w",stdout);scanf("%d",&n);for(int i=1;i<=n;i++){scanf("%d",&a[i]);ans+=a[i];}sort(a+1,a+n+1,greater<int>());memcpy(lsh,a,sizeof(a));cnt=unique(lsh+1,lsh+n+1)-lsh-1;for(int i=1,j=0;i<=n;i++){if(a[i]!=a[i-1])j++;num[j]++;}for(int i=1;i<=cnt;i++)sum[i]=sum[i-1]+num[i];for(int i=1;i<=cnt;i++){int k=min(num[i],sum[i-1]-tot*2);for(int j=1;j<=k;j++){st.push(lsh[i]);tot++;}for(int j=1;j<=num[i]-k;j+=2){if(q.empty())break;if(q.top()<lsh[i]){q.pop();st.push(lsh[i]);if(j!=num[i]-k){st.push(lsh[i]),tot++;}}else {if(j!=num[i]-k&&lsh[i]*2>q.top()){st.push(lsh[i]*2-q.top());tot++;st.push(q.top());q.pop();}}}while(!st.empty()){q.push(st.top());st.pop();}}while(!q.empty()){ans-=q.top();q.pop();}cout<<ans;
}

种树

又是反悔贪心。

按照降序贪心,对于一个已选的 $ a_i $ 只有同时选择 $ a_{i-1}和 a_{i+1} $ 才会反悔,链表维护,反悔时,更改 $ a_i $ 为 $ a_{i-1}+a_{i+1}-a_i $ 。

剩下的以后再写。

fw

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

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

相关文章

读数据保护:工作负载的可恢复性29新式的数据保护方案

新型数据保护方案1. 新式的数据保护方案 1.1. 产品都是围绕着磁盘设计的1.1.1. 许多产品只支持磁盘,另一些虽然支持磁带,但仍然是以磁盘为主的1.1.2. 产品都把磁盘作为首要的备份目标(而且通常只支持把数据备份到磁盘上)​1.2. 除了以磁盘为中心,这些产品还有一个共同之处…

WPF 测试 GlyphTypeface 的 Baseline 行为

本文将对 WPF 进行 GlyphTypeface 的 Baseline 行为测试。经过测试发现行为非常符合预期,这个值乘以字号就是基线本文内容里面只给出关键代码片段,如需要全部的项目文件,可到本文末尾找到本文所有代码的下载方法 前置博客: WPF 简单聊聊如何使用 DrawGlyphRun 绘制文本大飞…

OpenVX功能参数分析

3. 节点参数节点创建函数的参数定义为原子类型,如vx_int32、vx_enum,或对象,如vx_scalar、vx_image。框架应将节点创建功能的原子变量转换为vx_scalar引用,供节点使用。vx_scalar类型的节点参数,可以在图形执行期间更改;而如果改变原子类型的节点参数(vx_int32等),则至…

OpenVX参数节点执行独立性

8.节点执行独立性 在如图2-5所示例中,客户端根据输入图像、梯度幅度和梯度相位。OpenVX并不要求并行运行,但可以由OpenVX供应商实现。 图2-5 具有一些独立节点的简单图形。 构造这种图形的代码,如下所示。 vx_context context = vxCreateContext(); vx_image images[] = {…

4书推荐《AI芯片开发核心技术详解》、《智能汽车传感器:原理设计应用》、《TVM编译器原理与实践》、《LLVM编译器原理与实践》

4本书推荐《AI芯片开发核心技术详解》、《智能汽车传感器:原理设计应用》、《TVM编译器原理与实践》、《LLVM编译器原理与实践》由清华大学出版社资深编辑赵佳霓老师策划编辑的新书《AI芯片开发核心技术详解》已经出版,京东、淘宝天猫、当当等网上,相应陆陆续续可以购买。该…

BOF编写-修改时间戳

模板配置 跟着网上的教程使用evilashz师傅的模板,下载模板解压至vs的模板目录: %UserProfile%\Documents\Visual Studio 2022\Templates\ProjectTemplates​​ 创建新项目选择刚刚新增的类型:Beacon Object File​。 ​​ ‍ 环境适配 生成时报错,我使用的是2022版本的,模…

【分布式系统】 分布式调度 设计,要考虑 哪些问题?

一、分布式调度框架的核心功能二、什么是 任务调度 ?三、什么是分布式 任务调度 ?四、分布式调度框架的主要功能五、分布式调度框架的核心业务场景六、分布式任务调度的核心组件七、分布式任务调度的架构模式八、常见的分布式调度框架包括九、XXL-Job的工作流程十、 Quartz 的…

一文搞懂L1-L3业务流程体系分析,价值流、端到端流程、职能流程

今天我们聊聊业务流程体系分析这个话题。 业务流程的概念 业务流程是企业为实现目标而制定的一套系统化的工作方法。它由一系列有序的业务活动组成,按照既定规则将资源(输入)转化为有价值的结果(输出)。 在业务架构分析阶段,业务流程发挥着关键作用: • 明确业务运作的方…

[SSL/TLS/PKI] 基于`Let’s Encrypt`,获取免费SSL证书

缘起:云厂商卖的SSL证书太贵 概述:Let’s Encrypt 支持申请免费SSL证书的CA机构支持提供免费SSL证书的CA机构有:Let’s Encrypt ZeroSSL SSL For Free Cloudflare BuyPass AWS本文我们来试试 Let’s Encrypt 怎么用。https://letsencrypt.org/zh-cn/getting-started/Let’s …

.NET 响应式编程 System.Reactive 系列文章(二):深入理解 IObservableT 和 IObserverT

在 Rx 中,数据流的生产和消费是通过 观察者模式(Observer Pattern) 实现的。这种模式定义了两种角色: - IObservable.NET 响应式编程 System.Reactive 系列文章(二):深入理解 IObservable<T> 和 IObserver<T>引言:为什么我们调整了学习顺序? 在上一篇文章…

WebPack站点实战(一)

以下文章来源于一位不愿透露姓名的热心网友 ,作者不愿透露姓名的热心网友 文章配套B站视频,很多话语简略了,建议配着视频看。 地址:https://www.bilibili.com/video/BV13F411P7XB/ 开始之前了,简单过一下下面几个方法加深印象,便于更好理解加载器。也可以直接从webpack标…

CUDA概念

1.1.0f加个f,成单精度计算,不加会默认成double 2.快速指令:__add()加两个下划线 3.CUDA计算能力1.3以上才支持双精度,4.0往后支持双精度浮点计算 单精度浮点型(float )专指占用32位存储空间的单精度(single-precision )值。单精度在一些处理器上比双精度更快而且只占用…