3月21日考试 题解(数据结构+区间DP+贪心)
前言:T3写挂了,有点难受。
---------------
T1 中位数
题意简述:给你一段长度为$n$的序列,分别输出$[1,2k-1]$的中位数$(2k-1\leq n)$。
-------------
其实正解是用两个堆分别为大根堆和小根堆。但我这里偷了个懒,直接由STL函数upper_bound二分查找插入数字(STL大法好
Code:
#include<bits/stdc++.h>
using namespace std;
vector<int> v;
int n;
int main()
{
scanf("%d",&n);
for (int i=;i<=n;i++)
{
int x;
scanf("%d",&x);
v.insert(upper_bound(v.begin(),v.end(),x),x);
if (i%==)
printf("%d\n",v[(i-)/]);
}
return ;
}
T2 多边形
题意简述:给你一个有n个边的多边形,每个顶点上有一个数字,每条边上为$+$或$\times $ .现在去掉任意一条边,求运算的最大值.
--------------
这道题其实跟石子合并有点像,不过有一点要注意:1.子区间的合并受运算符号限制;2.可能有负数,所以我们同时要维护最小值,因为有可能负乘负大于当前数.
题目细节较多.
Code:
#include<bits/stdc++.h>
using namespace std;
const int maxn=;
int f[maxn*][maxn*][maxn*],mf[maxn*][maxn*][maxn*];
int ch[maxn*],a[maxn*];
int n,ans=-0x3f3f3f3f;
int maxx(int a,int b,int c,int d,int e)
{
return max(a,max(b,max(c,max(d,e))));
}
int minn(int a,int b,int c,int d,int e)
{
return min(a,min(b,min(c,min(d,e))));
}
int main()
{
scanf("%d",&n);
for (int i=;i<=n;i++)
for (int j=;j<=n*;j++)
for (int k=;k<=n*;k++) f[i][j][k]=-0x3f3f3f3f,mf[i][j][k]=0x3f3f3f3f;
for (int i=;i<=*n;i++)
{
if (i%==){
char c;cin>>c;
if (c=='t') ch[i/+]=;
else ch[i/+]=;
}
else cin>>a[i/];
}
for (int i=n+;i<=n*;i++)
{
a[i]=a[i-n];
ch[i]=ch[i-n];
}
for (int i=;i<=n;i++)
for (int j=;j<=n*;j++) f[i][j][j]=mf[i][j][j]=a[j];
for (int i=;i<=n;i++)
{
for (int len=;len<=n;len++)
{
for (int j=i;j<=i+n-;j++)
{
int k=j+len-;
if (k>=i+n) break;
for (int l=j;l<k;l++)
{
if (ch[l+]==) {
f[i][j][k]=max(f[i][j][k],f[i][j][l]+f[i][l+][k]);
mf[i][j][k]=min(mf[i][j][k],mf[i][j][l]+mf[i][l+][k]);
}
else{
f[i][j][k]=maxx(f[i][j][k],f[i][j][l]*f[i][l+][k],f[i][j][l]*mf[i][l+][k],mf[i][j][l]*f[i][l+][k],mf[i][j][l]*mf[i][l+][k]);
mf[i][j][k]=minn(mf[i][j][k],f[i][j][l]*f[i][l+][k],f[i][j][l]*mf[i][l+][k],mf[i][j][l]*f[i][l+][k],mf[i][j][l]*mf[i][l+][k]);
}
}
}
}
ans=max(ans,f[i][i][i+n-]);
}
printf("%d",ans);
return ;
}
T3 连锁店
题意简述:张三开了$n$个连锁店,每个连锁店能用$a_{i}$个空瓶换$b_{i}$瓶水.每个店都可以无限次兑换,现在李四有$s$瓶水,求最多的兑换次数.如果不存在输出$-1$.
$n\leq 100000$,$s,a_{i},b_{i}\leq 10^{19}$.
---------------------
无解的情况:当$s\geq a_{i}$并且$a_{i}\leq b_{i}$.在输入的时候顺便判断.
我们考虑贪心:以$a_{i}-b_{i}$作为关键字排序很显然差值越小,兑换次数越多.
记得开$unsigned$ $long$ $long$.
Code:
#include<bits/stdc++.h>
using namespace std;
typedef unsigned long long ll;
const int maxn = 1e5+,mod = 1e9+;
struct node{ll x,y,z;}a[maxn];
bool operator < (const node a,const node b){
if(a.z != b.z)return a.z < b.z;
return a.x<b.x;
}
int main()
{
int n,flag = ; ll s,ans = ;
scanf("%d%llu",&n,&s);
for(int i=;i<n;i++){
scanf("%llu%llu",&a[i].x,&a[i].y);
if(a[i].x>s)n--,i--;
else if(a[i].x<=a[i].y)flag = ;
a[i].z = a[i].x-a[i].y;
}
if(flag)return *puts("-1");
sort(a,a+n);
for(int i=;i<n;i++){
if(s>=a[i].x){
ll tmp = (s-a[i].x)/a[i].z+;
ans += tmp;
s -= tmp*a[i].z;
}
printf("%llu\n",ans);
return ;
}
3月21日考试 题解(数据结构+区间DP+贪心)的更多相关文章
- 3月28日考试 题解(二分答案+树形DP+数学(高精))
前言:考试挂了很多分,难受…… --------------------- T1:防御 题意简述:给一条长度为$n$的序列,第$i$个数的值为$a[i]$.现让你将序列分成$m$段,且让和最小的一段尽 ...
- 7月15日考试 题解(链表+状压DP+思维题)
前言:蒟蒻太弱了,全打的暴力QAQ. --------------------- T1 小Z的求和 题目大意:求$\sum\limits_{i=1}^n \sum\limits_{j=i}^n kth ...
- 7月13日考试 题解(DFS序+期望+线段树优化建图)
T1 sign 题目大意:给出一棵 N 个节点的树,求所有起点为叶节点的有向路径,其 上每一条边权值和的和.N<=10000 水题.考试的时候毒瘤出题人(学长orz)把读入顺序改了一下,于是很多 ...
- 6月28日考试 题解(GCD约分+动态规划+树状数组二维偏序)
前言:考的一般般吧……T3暴力没打上来挺可惜的,到手的75分没了. ---------------------------------- T1 [JZOJ4745]看电影 Description 听说 ...
- 2016年12月21日 星期三 --出埃及记 Exodus 21:16
2016年12月21日 星期三 --出埃及记 Exodus 21:16 "Anyone who kidnaps another and either sells him or still h ...
- 2016年11月21日 星期一 --出埃及记 Exodus 20:12
2016年11月21日 星期一 --出埃及记 Exodus 20:12 "Honor your father and your mother, so that you may live lo ...
- 2016年10月21日 星期五 --出埃及记 Exodus 19:5
2016年10月21日 星期五 --出埃及记 Exodus 19:5 Now if you obey me fully and keep my covenant, then out of all na ...
- 成都Uber优步司机奖励政策(2月21日)
滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...
- 长沙4月21日开发者大会暨.NET社区成立大会活动纪实
活动总结 2019年4月21日是一个斜风细雨.微风和煦的美好日子,由长沙.NET技术社区.腾讯云云加社区.微软Azure云技术社区.中国.NET技术社区.长沙柳枝行动.长沙互联网活动基地(唐胡子俱乐部 ...
随机推荐
- json转化为C#、Java、TypeScript、VisualBasic、Python实体类
效果展示: 源码下载地址:https://github.com/doyoulaikeme/DotNetSample/tree/master/DotNetSample2
- 一题搞定static关键字
基础不牢,地动山摇 开篇一道题,考察代码执行顺序: public class Parent { static { System.out.println("Parent static init ...
- day18 装饰器(下)+迭代器+生成器
目录 一.有参装饰器 1 前提 2 如何使用有参装饰器 3 有参装饰器模板 4 修正装饰器 二.迭代器 1 什么是迭代器 2 为什么要有迭代器 3 如何用迭代器 3.1 可迭代对象 3.2 可迭代对象 ...
- Alink漫谈(十) :线性回归实现 之 数据预处理
Alink漫谈(十) :线性回归实现 之 数据预处理 目录 Alink漫谈(十) :线性回归实现 之 数据预处理 0x00 摘要 0x01 概念 1.1 线性回归 1.2 优化模型 1.3 损失函数& ...
- Scala 基础(十一):Scala 函数式编程(三)高级(一)偏函数、作为参数的函数、匿名函数、高阶函数
1 偏函数 1)在对符合某个条件,而不是所有情况进行逻辑操作时,使用偏函数是一个不错的选择 2)将包在大括号内的一组case语句封装为函数,我们称之为偏函数,它只对会作用于指定类型的参数或指定范围值的 ...
- 3dTiles 数据规范详解[4.2] i3dm瓦片二进制数据文件结构
i3dm,即 Instanced 3D Model,实例三维模型的意思. 诸如树木.路灯.路边的垃圾桶.长椅等具有明显 重复 特征的数据.这类数据用得较少(笑,现在都喜欢搞BIM.倾斜摄影.精模.白模 ...
- 微信小程序随手笔记
1.全局导入vant时build后有问题(只能页面引入) 2.微信小程序只能用:https开头,在微信公众号里还要修改下配置 3.微信小程序里textarea与vant的van-popup有问题,手机 ...
- MySQL索引——总结篇
MySQL索引 MySQL索引 数据库的三范式,反模式 零碎知识 索引 索引原理 B Tree索引 B+Tree索引 B Tree 与 B+Tree的比较 聚集索引和辅助索引 聚集索引的注意事项 索引 ...
- python利用selenium(webdriver chrome)模拟登陆获取cookie
(我是在windows下进行实验的) 准备工作: 1.安装python环境. 2.python安装selenium插件(执行以下命令就行). pip install selenium 3.Wind ...
- JQuery对下拉列表Select的一些操作
1.假如select中存在选项,需要清空的情况: $("#search").find("option").remove(); $("#search&q ...