Problem A 表演

有$n$个有点权的点,$m$个有边权的边。对于每个点$u$,输出从这个点出发到$v$,其路径权值的两倍加上v的点权和最小的值。

对于$100\%$的数据,满足$1 \leq n,m \leq 2\times 10^5 $

Solution :

  考虑一个简单的转移,$f[u]$表示点$u$的最小答案,最初$f[u]$ 为$u$的点权。

  每一次更新,就是相邻的两个点$u,v$之间,用边权的两倍来更新答案。

  如果在图上DP,那么就相当于,将初始这些点权加入priority_queue,跑最短路即可。

  时间复杂度为$O(m log_2 n)$

# include <bits/stdc++.h>
# define int long long
using namespace std;
const int N=2e5+;
struct rec{ int pre,to,w;}a[N<<];
int n,m,tot;
bool inq[N];
int head[N],d[N],val[N];
namespace Fast_IO {
inline int read() {
int x=,w=; char c=;
while (c<''||c>'') w|=c=='-',c=getchar();
while (c>='' && c<='') x=(x<<)+(x<<)+(c^),c=getchar();
return w?-x:x;
}
void write(int x) {
if (x<) x=-x,putchar('-');
if (x>) write(x/);
putchar(''+x%);
}
void writeln(int x) {
write(x); putchar('\n');
}
};
using namespace Fast_IO;
void adde(int u,int v,int w) {
a[++tot].pre=head[u];
a[tot].to=v;
a[tot].w=w*;
head[u]=tot;
}
struct Node {
int id,val;
};
struct cmp {
bool operator () (Node a,Node b) {
return a.val > b.val;
}
};
priority_queue<Node,vector<Node>,cmp>q;
void dijkstra() {
for (int i=;i<=n;i++) {
d[i]=val[i];
inq[i]=true;
q.push((Node){i,val[i]});
}
while (q.size()) {
int u=q.top().id; q.pop(); inq[u]=false;
for (int i=head[u];i;i=a[i].pre) {
int v=a[i].to;
if (d[v]>d[u]+a[i].w) {
d[v]=d[u]+a[i].w;
if (!inq[v]) q.push((Node){v,d[v]});
}
}
}
}
signed main() {
n=read();m=read();
for (int i=;i<=m;i++) {
int u=read(),v=read(),w=read();
adde(u,v,w); adde(v,u,w);
}
for (int i=;i<=n;i++) val[i]=read();
dijkstra();
for (int i=;i<n;i++) write(d[i]),putchar(' ');
writeln(d[n]);
return ;
}

exciting.cpp

Problem B 逮虾户

 要求的车速是一个大于等于0的值,设第$i$次估计的车速为$v_i$,走的路程为$s_i$,

  设$v'$表示真实速度,则有偏差值$d$的定义式为 $d = v' - v_i$。

  考虑对速度的估计的偏差值d每一次都恒定。

  给出$n$次测算的结果$s_i , v_i$,和这几次测试总共的用时$t$,输出$d$的值。

  对于$100\%$的数据满足$1 \leq n\leq 10^3,1 \leq s_i \leq 10^3 , |v_i| \leq 10^3$

Solution :

  考虑$t$这个函数是在$n+1$段不连续的定义域中单调减的。

  所以,我们可以做$n+1$二分,就能找到些定义域中和d最相近的。

、 注意,最后统计答案的时候,需要check一下实际车速大于等于0.

  时间复杂度为$O(n ^2 log_2 S)$,其中$S$表示确定实数域大小。

# include <bits/stdc++.h>
using namespace std;
const int N=1e3+;
const double eps = 1e-;
struct rec{double s,v;}a[N];
int n,t;
vector<double>ans;
bool cmp (rec x, rec y) {
return x.v>y.v;
}
double f (double x) {
double res = ;
for (int i=;i<=n;i++) res += (double)a[i].s/(double)(x+a[i].v);
return res;
}
double work(double l,double r) {
while (fabs(r-l)>=eps) {
double mid = (l+r)/2.0;
if (f(mid)<=t) r=mid;
else l=mid;
}
return l;
}
double calc(double x) {
return fabs(f(x)-t);
}
int main() {
scanf("%d%d",&n,&t);
for (int i=;i<=n;i++) scanf("%lf%lf",&a[i].s,&a[i].v);
sort(a+,a++n,cmp);
double l=-1e9;
for (int i=;i<=n;i++) {
ans.push_back(work(l,-a[i].v-eps));
l=-a[i].v+eps;
}
ans.push_back(work(l,1e9));
double res = ans[], delta =calc(ans[]);
for (int i=;i<ans.size();i++) {
bool ok = true;
for (int j=;j<=n;j++) if (a[j].v+ans[i]<eps) {
ok = false; break;
}
if (!ok) continue;
double tmp = calc(ans[i]);
if (tmp <= delta) {
res = ans[i]; delta = tmp;
}
}
printf("%.10lf\n",res);
return ;
}

dejavu.cpp

Problem C 跳一跳

  如果序列中任意相邻两个元素,都是极值点,其中一个是极大值点,另外一个极小值点。

   那么这个序列叫做波浪序列。

  给出对于长度为$n$序列,输出最长波浪序列的长度。

  对于$100\%$的数据满足 $1 \leq n \leq 10^5 , 1 \leq a_i \leq 10^9 $

Solution :

  由于元素只进行比较,所以我们可以将其离散化。

  设$f[i][0]$表示第$i$个元素作为极小点为结尾的最长波浪序列长度,$f[i][1]$表示第$i$个元素作为极大点为结尾的最长波浪序列长度。

  转移方程为:$f[i][0] = max(f[j][1] + 1) (a_i < a_j) , f[i][1] = max (f[j][0] + 1) (a_i > a_j)$

  可以用值域线段树来维护这个$DP$。时间复杂度为$O(n log_2 n)$

# include <bits/stdc++.h>
using namespace std;
const int N=1e5+;
int a[N],n,f[N][];
vector<int>tmp;
namespace Fast_IO {
inline int read() {
int x=,w=; char c=;
while (c<''||c>'') w|=c=='-',c=getchar();
while (c>='' && c<='') x=(x<<)+(x<<)+(c^),c=getchar();
return w?-x:x;
}
void write(int x) {
if (x<) x=-x,putchar('-');
if (x>) write(x/);
putchar(''+x%);
}
void writeln(int x) {
write(x); putchar('\n');
}
};
using namespace Fast_IO;
struct Segment_Tree {
int tr[N<<];
# define ls (x<<)
# define rs (x<<|)
# define mid (l+r>>)
# define lson ls,l,mid
# define rson rs,mid+,r
void update(int x,int l,int r,int pos,int opx) {
if (l==r) {
tr[x]=max(tr[x],opx);
return;
}
if (pos<=mid) update(lson,pos,opx);
else update(rson,pos,opx);
tr[x]=max(tr[ls],tr[rs]);
}
int query(int x,int l,int r,int opl,int opr) {
if (opl<=l && r<=opr) return tr[x];
int ret=;
if (opl<=mid) ret=max(ret,query(lson,opl,opr));
if (opr>mid) ret=max(ret,query(rson,opl,opr));
return ret;
}
}tr0,tr1;
int main() { n=read();
for (int i=;i<=n;i++) {
tmp.push_back(a[i]=read());
}
sort(tmp.begin(),tmp.end());
tmp.erase(unique(tmp.begin(),tmp.end()),tmp.end());
int m = tmp.size();
for (int i=;i<=n;i++) {
a[i]=lower_bound(tmp.begin(),tmp.end(),a[i])-tmp.begin()+;
}
int ans = ;
for (int i=;i<=n;i++) {
f[i][]=f[i][]=;
if (a[i]->=) f[i][] = max(f[i][],tr0.query(,,m,,a[i]-)+);
if (a[i]+<=m) f[i][] = max(f[i][],tr1.query(,,m,a[i]+,m)+);
ans = max(ans,max(f[i][],f[i][]));
tr0.update(,,m,a[i],f[i][]);
tr1.update(,,m,a[i],f[i][]);
}
writeln(ans);
return ;
}

jump.cpp

HGOI20191115 模拟赛 题解的更多相关文章

  1. NOIP第7场模拟赛题解

    NOIP模拟赛第7场题解: 题解见:http://www.cqoi.net:2012/JudgeOnline/problemset.php?page=13 题号为2221-2224. 1.car 边界 ...

  2. 大家AK杯 灰天飞雁NOIP模拟赛题解/数据/标程

    数据 http://files.cnblogs.com/htfy/data.zip 简要题解 桌球碰撞 纯模拟,注意一开始就在袋口和v=0的情况.v和坐标可以是小数.为保险起见最好用extended/ ...

  3. 20220303模拟赛题解and总结

    目录 总结 A.不幸的7 B.选举 C. 差的绝对值之和 D. 路径通过 总结 初一第一 一般,最后一题没打好 不难发现,教练出水了,可能是信心赛 A.不幸的7 暴力,没有逻辑可言 #include& ...

  4. 【洛谷】xht模拟赛 题解

    前言 大家期待已久并没有的题解终于来啦~ 这次的T1和HAOI2016撞题了...深表歉意...表示自己真的不知情... 天下的水题总是水得相似,神题各有各的神法.--<安娜·卡列妮娜> ...

  5. PKUSC 模拟赛 题解_UPD

    之前挖了两个大坑 一个是day1下午的第二题 另一个是day2上午的第五题 先说day1下午的第二题吧 我们显然不能O(n^2)的dp,所以我们只能算贡献 首先对于任意一个边界点而言,他对答案的贡献路 ...

  6. 10.6-10.7 牛客网NOIP模拟赛题解

    留个坑... upd:估计这个坑补不了了 如果还补不了就删了吧

  7. 2019 蓝桥杯国赛 B 组模拟赛 题解

    标签 ok #include<bits/stdc++.h> using namespace std; /* 求阶乘 去除尾部0 每次求阶乘时:结果去除尾0,并对 1e6取余 */ type ...

  8. 『7.5 NOIP模拟赛题解』

    T1 Gift Description ​ 人生赢家老王在网上认识了一个妹纸,然后妹纸的生日到了,为了表示自己的心 意,他决定送她礼物.可是她喜爱的东西特别多,然而他的钱数有限,因此他想 知道当他花一 ...

  9. 『7.3 NOIP模拟赛题解』

    T1 gift Description ​ 夏川的生日就要到了.作为夏川形式上的男朋友,季堂打算给夏川买一些生日礼物. ​ 商店里一共有种礼物.夏川每得到一种礼物,就会获得相应喜悦值Wi(每种礼物的喜 ...

随机推荐

  1. DP+线段树维护矩阵(2019牛客暑期多校训练营(第二场))--MAZE

    题意:https://ac.nowcoder.com/acm/contest/882/E 给你01矩阵,有两种操作:1是把一个位置0变1.1变0,2是问你从第一行i开始,到最后一行j有几种走法.你只能 ...

  2. centos7.2 安装Lnmp

    1. 安装编译工具及库文件 yum install -y make apr* autoconf automake curl  \ curl-devel gcc gcc-c++ cmake gtk+-d ...

  3. 【转】三种方法让你在I2C通信中同时和多个从机通信

    ref:http://tieba.baidu.com/p/3769008030 对于不同地址的模块就不用多说了,直接分别对其地址进行通信即可.那么若拿到相同地址的模块,或者直接是相同的多个模块怎么办呢 ...

  4. Python取值的灵活性用法

    samp_string = "Whatever you are, be a good one." for i in samp_string: print(i) ,len(samp_ ...

  5. 工作单元 — Unit Of Work

    在进行数据库添加.修改.删除时,为了保证事务的一致性,即操作要么全部成功,要么全部失败.例如银行A.B两个账户的转账业务.一方失败都会导致事务的不完整性,从而事务回滚.而工作单元模式可以跟踪事务,在操 ...

  6. ES6中Map与其他数据结构的互相转换

    最近在学习ES6的基础知识,整理了一下Map与其他数据结构相互转换的写法. Map转为数组的方法 let myMap = new Map([[true, 7], [{foo: 3}, ['abc']] ...

  7. python+django学习一

    pycharm破解地址:https://blog.csdn.net/qq_32811489/article/details/78636049 按照视频写代码,记录关键的地方方便自己记忆, 视频教程地址 ...

  8. host缓存,浏览器缓存---解决host缓存带来的伤

    1.缓存 缓存,对应工程师来讲简直太熟悉了,太方便了,省略到资源或数据的获取方式,直接缓存到离用户访问最快的地方,也降低服务器的压力,比如: (1)静态文件获取 服务器->cdn->本地磁 ...

  9. 使用postman创建Marketing Cloud的Contact

    首先在Marketing Cloud的UI上创建一个contact: 观察Chrome开发者工具network标签页里的HTTP请求: https://jerry.gcdemo.hybris.com/ ...

  10. asp.net 身份验证(Update)

    ASP.NET   有四种 身份验证, 用的最广的就是 Froms   这几天 做项目    想用到 配置文件, 比较了 MVC 和ASP.NET  发现 还是 MVC 给力(MVC 叫做 过滤器  ...