2024.11.12 总结

news/2024/11/14 9:10:49/文章来源:https://www.cnblogs.com/Kang-shifu/p/18542710

D.公路修建问题

OI island是一个非常漂亮的岛屿,自开发以来,到这儿来旅游的人很多。然而,由于该岛屿刚刚开发不久,所以那 里的交通情况还是很糟糕。所以,OIER Association组织成立了,旨在建立OI island的交通系统。 OI island有n 个旅游景点,不妨将它们从1到n标号。现在,OIER Association需要修公路将这些景点连接起来。一条公路连接两 个景点。公路有,不妨称它们为一级公路和二级公路。一级公路上的车速快,但是修路的花费要大一些。 OIER As sociation打算修n-1条公路将这些景点连接起来(使得任意两个景点之间都会有一条路径)。为了保证公路系统的 效率, OIER Association希望在这n-1条公路之中,至少有k条(0≤k≤n-1)一级公路。OIER Association也不希望为 一条公路花费的钱。所以,他们希望在满足上述条件的情况下,花费最多的一条公路的花费尽可能的少。而你的任 务就是,在给定一些可能修建的公路的情况下,选择n-1条公路,满足上面的条件。

输入格式

第一行有三个数n(1≤n≤10000),k(0≤k≤n-1),m(n-1≤m≤20000),这些数之间用空格分开。N和k如前所述,m表示有m对景点之间可以修公路。

以下的m-1行,每一行有4个正整数a,b,c1,c2(1≤a,b≤n,a≠b,1≤c2≤c1≤30000)

表示在景点a与b之间可以修公路,如果修一级公路,则需要c1的花费,如果修二级公路,则需要c2的花费。



形式化:一张图的边有两种边权,求一棵最小生成树使得至少包含k条第一种边。发现形式化题意看完了也就做完了。

显然出题人不希望我们这样做,如果这道题二级公路可以比一级公路贵这种方法就没法做了,所以可以二分答案,然后每次二分往生成树里放k条一级公路。

#include <bits/stdc++.h>
using namespace std;
const int N=1e4+5,M=2e4+5;
int fa[N];
struct type {int u,v,w,t;int index,choo;
}a[M],b[M];
vector<type> e;
int find(int x){if(x==fa[x]) return x;else return fa[x]=find(fa[x]);
}
void unite(int x,int y){fa[find(x)]=find(y);
}
bool cmp(type a,type b){return a.w<b.w;
}
bool cmp2(type a,type b){return a.t<b.t;
}
bool cmp3(type a,type b){return a.index<b.index;
}
int n,k,m,ta,tb;
int tc1,tc2,m1,ans;
int main()
{cin>>n>>k>>m;for(int i=1;i<=m-1;i++){cin>>ta>>tb>>tc1>>tc2;a[++m1].u=ta,a[m1].v=tb;a[m1].w=tc2,a[m1].t=tc1,a[m1].index=i;}for(int i=1;i<=n;i++) fa[i]=i;sort(a+1,a+m1+1,cmp2);int i;for(i=1;i<=m1&&k;i++){if(find(a[i].u)!=find(a[i].v)){unite(a[i].u,a[i].v);ans=max(ans,a[i].t);k--;a[i].choo=1;e.push_back(a[i]);}}sort(a+i,a+m1+1,cmp);for(;i<=m1;i++){if(find(a[i].u)!=find(a[i].v)){unite(a[i].u,a[i].v);ans=max(ans,a[i].w);a[i].choo=2;e.push_back(a[i]);}}cout<<ans<<endl;//sort(e.begin(),e.end(),cmp3);//for(int i=0;i < (int)e.size();i++)//	cout<<e[i].index<<' '<<e[i].choo<<endl;return 0;
}



#吃草 为了庆祝奶牛Bessie的生日,Farmer John给了她一块最好的牧场,让她自由的享用。

牧场上一共有N块草地(1≤N≤1000),编号为1...N,每块草地上牧草的质量都不同。

如果Bessie吃掉的草地上牧草质量为Q,她可以获得Q单位的能量。

每块草地最多和10块草地有相连的道路,在相连的两个草地之间走动需要消耗E单位的能量(1≤E≤1,000,000)。

Bessie可以从任意一块草地开始吃草,并且想要在获得了最多能量的时候停止。

有点遗憾的,Bessie是一头挑食的奶牛,一旦她吃过了一定质量的牧草,她就不会再吃相同或更低质量的牧草!但是她仍然很愿意路过某些草地,而不吃它们。实际上,她发现路过一块高质量的草地而不吃它,等一下返回再去享用,有时会更有利!

请帮忙计算Bessie能够获得的能量的最大值。

发现往返两点之间的最短代价就是最小路径,而最优解的构造方法是从小到大把每块草地的质量排序,然后挨个吃。有的草地吃了它可能会亏,所以就把他踢出去。这样就可以构造一个dp。Fi表示吃第i块草的最大收益。Fi = max(Fj - DISij + VALj)

#include<bits/stdc++.h>
using namespace std;
constexpr int maxn = 2010;
int n, E;
struct edge{int to,next,val;
}e[maxn * 10];
int head[maxn];
int cnt;
void addedge(int u,int v){e[++cnt].to = v;e[cnt].val = E;e[cnt].next = head[u];head[u] = cnt;
}
int dis[maxn][maxn];
bool vis[maxn];
struct node{int dis,pos;bool operator<(const node x) const{return dis > x.dis;}
};
constexpr int inf = 1e9;
void djstl(int S){priority_queue<node> q;for(int i = 0;i < maxn;i++) dis[S][i] = inf,vis[i] = false;q.push((node){0,S});dis[S][S] = 0;while(!q.empty()){node temp = q.top();q.pop();int x = temp.pos;if(vis[x]) continue;vis[x] = true;for(int i = head[x];i;i = e[i].next){int y = e[i].to;if(dis[S][x] + e[i].val < dis[S][y]){dis[S][y] = dis[S][x] + e[i].val;if(!vis[y]){q.push((node){dis[S][y],y});}}}}
}void getdis(){for(int i = 1;i <= n;i++){djstl(i);}
}int dp[maxn];
struct grass{int val,cur;bool operator <(grass x) const{return val < x.val;}
}grass[maxn];int main(){cin>>n>>E;for(int i = 1;i <= n;i++){int q,d;cin>>q>>d;grass[i].val = q;grass[i].cur = i;for(int j = 1;j <= d;j++){int v;cin>>v;addedge(i,v);}}getdis();for(int i=0;i<=n;++i)dis[0][i]=0;sort(grass+1,grass+n+1);for(int i = 1;i <= n;i++) dp[i] = grass[i].val;int ans = 0;for(int i = 1;i <= n;i++){for(int j = 1;j < i;j++){dp[i] = max(dp[i],dp[j] - dis[grass[j].cur][grass[i].cur]+grass[i].val);}ans = max(ans,dp[i]);}cout<<ans<<endl;return 0;
}

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

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

相关文章

全局平衡二叉树 (GBST) 小记

全局平衡二叉树 (GBST) 小记 以下全局平衡二叉树简称 \(\text{GBST(Globel Balanced Search Tree)}\)。 我认识的大多数人,对 \(\text{GBST}\) 的理解基本上都是 静态 \(\text{LCT}\),或者静态 \(\text{Top Tree}\),不过我对 \(\text{LCT}\) 的理解可能还差一点,所以我不打…

考研打卡(15)

开局(15) 开始时间 2024-11-12 20:37:51 结束时间 2024-11-12 22:41:32现在在敷泥膜数据结构设已知一稀疏矩阵的三元组表为:(1,2,3),(1,6,1),(3,1,5),(3,2,-1) (5,4,5),(5,1,-3),则其转置矩阵的三元组表中的第三个三元组为____(山东大学2013年) A (2,…

25. 使用MySQL之使用触发器

1. 触发器 MySQL语句在需要时被执行,存储过程也是如此。但是,如果你想要某条语句(或某些语句)在事件发生时自动执行,怎么办呢?例如:每当增加一个顾客到某个数据库表时,都检查其电话号码格式是 否正确,州的缩写是否为大写;每当订购一个产品时,都从库存数量中减去订购…

Mysql表分区实操

创建分区表 create table user(id int(11) not null,name varchar(32) not null) partition by range(id) ( partition p0 values less than(10), partition p1 values less than(20), partition p2 values less than(30), partition p3 values less than maxvalue )分区表数据…

【Azure Bot Service】部署NodeJS ChatBot代码到App Service中无法自动启动

问题描述 把NodeJS的ChatBot代码部署到App Service环境中,通过VS Code直接部署,显示部署成功。但是通过URL访问时候,却是 :( Application Error 。问题解答 App Service遇见Application Error,第一步,查看日志。 发现启动时候遇见: 2024-11-12T12:22:40.366223350Z Error…

Chrome如何卸载掉插件?如此简单!

前言 我之前由于好奇,一下子装了很多的chrome插件,这些插件虽然都有很多功能,但是,由于我的电脑性能不佳,浏览器一下子装这么多插件,有点带不动了。所以,我就想到了卸载谷歌浏览器,哦不,是卸载浏览器里面的插件。今天,我就来介绍下,如何在chrome里面卸载一些不常用的…

rocky9如何重置root密码

rocky9如何重置root密码 第一步第二步 在箭头指的地方把 "ro" 改成 "rw"另一个箭头指的地方写上如下内容:init=/bin/bash如图所示第三步 Ctrl + x 按当前的配置启动第四步 输入命令root 用户密码直接输入以下内容passwd如果更改其他用户第五步 最为关键的…

多校A层冲刺NOIP2024模拟赛21

多校A层冲刺NOIP2024模拟赛21\(T1\) A. 送信卒 \(90pts/100pts\)部分分\(90pts\)设最后的可能的最短路中左右共移动了 \(d\) 次,上下共移动了 \(x\) 次。则等价于求 \(\min \{ x_{i}k+d_{i} \}=s\) 的解,观察到 \(d \in [0,\min(\left\lceil \frac{nm}{2} \right\rceil,s)]\)…

[论文阅读] ZePo: Zero-Shot Portrait Stylization with Faster Sampling

写在前面 原文:ZePo GitHub:Github ZePo 关键词:肖像风格化、扩散模型、零样本快速生成 阅读理由:对扩散模型的改进,可以实现零样本快速生成图像,学习一下思路以及实验设计 前置知识:LCM以及GithubLCM(找时间写一下),可参考LCM&CM,一致性蒸馏、图像质量评价速览…

2024.11.12 鲜花

P11270 【MX-S5-T4】魔法少女们 题解这世界那么多人 这世界有那么多人 人群里 敞着一扇门 我迷朦的眼睛里长存 初见你蓝色清晨 这世界有那么多人 多幸运 我有个我们 这悠长命运中的晨昏 常让我 望远方出神 灰树叶飘转在池塘 看飞机轰的一声去远乡 光阴的长廊 脚步声叫嚷 灯一亮…

Java代码实现行列转换

本代码想要达到的效果 测试完整代码如下(copy直接运行): public class TestConvert { public static void main(String[] args) { ArrayList<Attribute> sourceList = new ArrayList<>(); for (int i = 0; i < 3; i++) { for (i…

SS241112A. 定向越野(walk)

这道题目要求找到从起点出发遍历所有点并回到起点的最小路径长度,路径必须直角拐弯。文章证明了答案是有理数,并通过直观分析和大胆猜测得出初始方向必须是某一个向量的方向,最终使用状压 DP 解决问题,时间复杂度为 $O(n^4 2^n)$。SS241112A. 定向越野(walk) 题意 给你 \…