NK16
C 小石的海岛之旅
链接:https://ac.nowcoder.com/acm/contest/949/C
来源:牛客网
从水平方向看海岛可以看成 nnn个小块,每一个小块都有一个高度hih_ihi,
水位一开始为 000,随着水位的上升,海岛分成了若干块。
现在有 mmm 个询问,求当水位为aia_iai 时,海岛会分成多少块。
输入描述:
第一行输入两个正整数n,mn,mn,m,分别表示海岛小块个数和询问个数。
第二行输入 nnn 个整数 hih_ihi,表示每一块的高度。
第三行输入 mmm个整数 aia_iai,表示每一个询问,保证输入的 aia_iai 单调递增。
输出描述:
共 mmm 行,分别对应 mmm 个询问的答案。
说明
当水位高度为 1 时,岛屿被分成 3 块,2 3;2;3 当水位高度为 2 时,岛屿被分成 2 块:3;3 。 当水位高度为 3 时,岛屿全部被淹没,剩余 0 块 。
思路:只有当左边的高度比水位低,右边的高度比水位高的时候才会被分割
#include<bits/stdc++.h>
using namespace std;
const int N=1E3+;
int arr[N];
int main(){
int n,m;
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++){
scanf("%d",&arr[i]);
}
int y;
for(int j=;j<=m;j++){
scanf("%d",&y);
int x=;
for(int i=;i<=n;i++){
if(arr[i]>y&&arr[i-]<=y){
x++;
}
}
printf("%d\n",x);
}
return ;
}
D 小杨买水果
链接:https://ac.nowcoder.com/acm/contest/949/D
来源:牛客网
小阳对每个水果都有一个喜爱程度 aia_iai,最终的满意度为他买到的水果的喜欢程度之和。
如果和为正(不管是正多少,只要大于 000 即可),他就满意了。
你能帮帮他吗?
输入描述:
第一行输入一个正整数 n,表示水果总数。 第二行输入 n 个整数 aia_iai,表示小阳对每个水果的喜爱程度。
输出描述:
一行一个整数表示结果。(如果 1 个水果都买不了,请输出 0)
输出
1
题解:构造一个前缀和,并对前缀和进行排序,从小到大排序,前缀和相同的,下标大的在前边,我要让起始点参与排序,因为有可能某一个前缀本身就是最优解,(不太理解)
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=2E6+;
int arr[N];
struct stu{
int a;
int b;
bool friend operator<(const stu &x,const stu &y){
if(x.a!=y.a)return x.a<y.a;
return x.b>y.b;
}
}sum[N];
int main(){
int n;
cin>>n;
sum[].a=;
for(int i=;i<=n;i++){
scanf("%d",&arr[i]);.
sum[i].a=sum[i-].a+arr[i];
sum[i].b=i;
}
sort(sum,sum++n);
int min1=n+;
int ans=;
for(int i=;i<=n;i++){
ans=max(ans,sum[i].b-min1);
min1=min(sum[i].b,min1);
}
cout<<ans<<endl;
return ;
}
第二种解法:二分!!(还是不理解)
#include <iostream>
#include <cstdio>
#include <algorithm>
using namespace std;
typedef long long ll;
const int MAX = 1e6*+;
ll a[MAX];
ll x,w;
int ans; int main(){
int n;
scanf("%d",&n);
for (int i = ; i <= n;i++){
scanf("%lld",&x);
w+=x;
a[i]=min(a[i-],w); if(w>){//总和大于0,特判
ans=max(ans,i);//不需要减1
continue;
} int l=,r=i;
while(l<=r){//二分找左边最小值
int mid=(l+r)>>;
if(a[mid]<w) r=mid-;
else l=mid+;
}
ans=max(ans,i-r-);//需要减1,自己推一下,不好解释~~(
//大体就是找到右边小于0的那一块,多了一个负值,把多的那个值去掉,右边就是大于0的,
//当然那个负值在右边那一块的最左边) }
printf("%lld\n",ans);
return ;
}
NK16的更多相关文章
- 详谈Format String(格式化字符串)漏洞
格式化字符串漏洞由于目前编译器的默认禁止敏感格式控制符,而且容易通过代码审计中发现,所以此类漏洞极少出现,一直没有笔者本人的引起重视.最近捣鼓pwn题,遇上了不少,决定好好总结了一下. 格式化字符串漏 ...
随机推荐
- FTP服务器与客户端的安装与配置
FTP服务器安装与配置 1. 切换到root用户: su root 2. 查看系统中是否安装了vsftpd,可以通过执行命令 : rpm -qa | grep vsftpd 3. 如果没有安装 v ...
- 搭建Hadoop集群需要注意的问题:
搭建Hadoop集群需要注意的问题: 1.检查三台主机名是否正确 2.检查三台IP是否正确 3.检查 /etc/hosts 映射是否正确 4.检查 JDK和Hadoop 是否安装成功(看环境变量配置) ...
- imread()用法|| root权限
1.ushort用法? USHORT is a macro which is not part of the official C++ language (it's probably defined ...
- 干货 | Python进阶系列之学习笔记(四)
目录 Python条件判断 Python循环语句 Python循环控制 迭代器与生成器 异常 一.Python 条件判断 如果某些条件满足,才能做某件事情:条件不满足时,则不能做,这就是所谓的判断. ...
- Linux常用命令 - find命令基础使用(重点)
1篇测试必备的Linux常用命令,每天敲一篇,每次敲三遍,每月一循环,全都可记住!! https://www.cnblogs.com/poloyy/category/1672457.html 首先,先 ...
- .Net Core2.2 使用 AutoMapper进行实体转换
一.遇到的问题 在. Core Api 的编写中,我们经常会对一些功能点进行新增编辑操作,同时我们有时也会进行查询,但是我们查询的表的数据与我们返回的数据相差甚大,这是我们有需要自己手动进行类型的转换 ...
- AttributeError: module 'tensorflow.python.keras.backend' has no attribute 'get_graph'处理办法
原因:安装的tensorflow版本和keras版本不匹配,只需卸载keras,重新安装自己tensorflow对应的版本. Keras与tensorflow版本匹配查询网站
- 一篇漫画故事带你理解透HTTPS(下)
上下集知识点总结: 前情提要: 蝙蝠纪元,疫情之下.二丫欲访问京东购物,不料弹出安全提示,遂找二毛一探究竟.二毛一顿排查后,开始用通俗易懂的语言深入浅出的向二丫解释 HTTP作用及优缺点.HTTPS的 ...
- centos7中安装mysql
centos7中安装mysql网上已经很多资源了,我就不在赘述了.我这里只是记录下我安装的时候出现的一些问题. 原文:https://www.cnblogs.com/bigbrotherer/p/72 ...
- 编写SpringBoot 中的AOP
编写SpringBoot 中的AOP 在程序开发的过程中会使用到AOP的思想,面向切面进行开发,比如登录的验证,记录日志等等-频繁需要操作的步骤,在遇到这种情况时就要使用Spring 的AOP了 Sp ...