https://www.nowcoder.com/acm/contest/124#question

题意  找第一个不小于K的数的下标,然后对它前一个数加一

解析   我们可以维护一个最大值数组  1到 i的 最大值 就是max[ i ]  二分找到最左边的值 但是 找到的前一个加1 要用线段树来维护最大值

但是 这么写会超时。。。

超时代码

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const ll mod=,maxn=1e6+;
int sum[maxn<<];
int a[maxn],n,m;
void PushUP(int rt)
{
sum[rt]=max(sum[rt<<],sum[rt<<|]);
}
void Build(int l,int r,int rt)
{
if(l==r)
{
sum[rt]=a[l];
return; }
int m=(l+r)>>;
Build(l,m,rt<<);
Build(m+,r,rt<<|);
PushUP(rt);
}
void Update(int L,int C,int l,int r,int rt)
{
if(l==r)
{
sum[rt]+=C;
return;
}
int m=(l+r)>>;
if(L<=m)
Update(L,C,l,m,rt<<);
else
Update(L,C,m+,r,rt<<|);
PushUP(rt);
}
int Query(int L,int R,int l,int r,int rt)
{
if(L<=l&&r<=R)
{
return sum[rt];
}
int m=(l+r)>>;
int ans=-;
if(L<=m)
ans=max(ans,Query(L,R,l,m,rt<<));
if(R>m)
ans=max(ans,Query(L,R,m+,r,rt<<|));
return ans;
}
int main()
{
while(scanf("%d%d",&n,&m)!=EOF)
{
memset(sum,,sizeof(sum));
memset(a,,sizeof(a));
for(int i=; i<=n; i++)
{
scanf("%d",&a[i]);
}
Build(,n,);
int l,r,k;
while(m--)
{
l=,r=n;
scanf("%d",&k);
//cout<<Query(1,n,1,n,1)<<endl;
if(Query(,n,,n,)<k)
{
printf("are you ok\n");
continue;
}
while(l<=r)
{
int mid=(l+r)>>;
// cout<<mid<<" "<<Query(1,mid,1,n,1)<<endl;
if(Query(,mid,,n,)>=k)
r=mid-;
else
l=mid+;
}
printf("%d\n",l-);
if(l-)
Update(l-,,,n,);
}
}
}

q的 询问比较多应该是卡了常数  我们要优化一下  因为 线段树查询的时候就是二分  区间最大值是递增的 我们直接利用这个特点来操作

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const ll mod=,maxn=1e6+;
int sum[maxn<<];
int a[maxn],n,m;
void PushUP(int rt)
{
sum[rt]=max(sum[rt<<],sum[rt<<|]);
}
void Build(int l,int r,int rt)
{
if(l==r)
{
sum[rt]=a[l];
return; }
int m=(l+r)>>;
Build(l,m,rt<<);
Build(m+,r,rt<<|);
PushUP(rt);
}
void Update(int L,int C,int l,int r,int rt)
{
if(l==r)
{
sum[rt]+=C;
return;
}
int m=(l+r)>>;
if(L<=m)
Update(L,C,l,m,rt<<);
else
Update(L,C,m+,r,rt<<|);
PushUP(rt);
}
int query(int L,int R,int l,int r,int rt,int p)
{
if(l==r)
{
return l;
}
int m=(l+r)>>;
if(sum[rt<<]>=p) //二分查询
return query(L,R,l,m,rt<<,p);
return query(L,R,m+,r,rt<<|,p);
}
int main()
{
while(scanf("%d%d",&n,&m)!=EOF)
{
memset(sum,,sizeof(sum));
memset(a,,sizeof(a));
for(int i=; i<=n; i++)
{
scanf("%d",&a[i]);
}
Build(,n,);
int l,r,k;
while(m--)
{
l=,r=n;
scanf("%d",&k);
if(sum[]<k)
{
printf("are you ok\n");
continue;
}
int ans=query(,n,,n,,k);
printf("%d\n",ans-);
if(ans-)
Update(ans-,,,n,);
}
}
}

其实 还有更简单的做法 因为 修改的是前一个值 而且找的是满足条件中最左边的 所以前一个+1 并不会 影响数组的单调性 变得只有前面一个的最大值  更新一下就好了

#include<bits/stdc++.h>
using namespace std;
int a[],b[];
int n,q,k;
int main()
{
while(~scanf("%d%d",&n,&q))
{
int mx=;
for(int i=;i<n;i++)
{
scanf("%d",&a[i]);
b[i]=mx=max(mx,a[i]);
}
while(q--)
{
scanf("%d",&k);
int l=lower_bound(b,b+n,k)-b;
if(l==n){
printf("are you ok\n");
continue;
}
printf("%d\n",l);
if(l==)continue;
a[l-]++;
b[l-]=max(a[l-],b[l-]);
}
}
}

牛客网 中南林业科技大学第十一届程序设计大赛J题 二分+线段树的更多相关文章

  1. 中南林业科技大学第十一届程序设计大赛 有趣的二进制 牛客网 java大数的一些方法

    链接:https://www.nowcoder.com/acm/contest/124/C来源:牛客网 题目描述 小新在学C语言的时候,邝老师告诉他double类型的数据在表示小数的时候,小数点后的有 ...

  2. 中南林业科技大学第十一届程序设计大赛- I:背包问题

    链接:https://www.nowcoder.com/acm/contest/124/I来源:牛客网 时间限制:C/C++ 2秒,其他语言4秒空间限制:C/C++ 131072K,其他语言26214 ...

  3. 中南林业科技大学第十一届程序设计大赛-C:有趣的二进制

    链接:https://www.nowcoder.com/acm/contest/124/C来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒空间限制:C/C++ 131072K,其他语言26214 ...

  4. 牛客网 桂林电子科技大学第三届ACM程序设计竞赛 G.路径-带条件的树的直径变形-边权最大,边数偶数的树上的最长路径-树形dp

    链接:https://ac.nowcoder.com/acm/contest/558/G 来源:牛客网 路径 小猫在研究树. 小猫在研究路径. 给定一棵N个点的树,每条边有边权,请你求出最长的一条路径 ...

  5. 牛客网 桂林电子科技大学第三届ACM程序设计竞赛 D.寻找-树上LCA(树上a到b的路径上离c最近的点)

    链接:https://ac.nowcoder.com/acm/contest/558/D来源:牛客网 寻找 小猫在研究树. 小猫在研究树上的距离. 给定一棵N个点的树,每条边边权为1. Q次询问,每次 ...

  6. 牛客网 桂林电子科技大学第三届ACM程序设计竞赛 C.二元-K个二元组最小值和最大-优先队列+贪心(思维)

    链接:https://ac.nowcoder.com/acm/contest/558/C来源:牛客网 小猫在研究二元组. 小猫在研究最大值. 给定N个二元组(a1,b1),(a2,b2),…,(aN, ...

  7. 牛客网 桂林电子科技大学第三届ACM程序设计竞赛 A.串串-后缀自动机模板题

    链接:https://ac.nowcoder.com/acm/contest/558/A来源:牛客网 A.串串 小猫在研究字符串. 小猫在研究字串. 给定一个长度为N的字符串S,问所有它的子串Sl…r ...

  8. 牛客wannafly 挑战赛14 B 前缀查询(trie树上dfs序+线段树)

    牛客wannafly 挑战赛14 B 前缀查询(trie树上dfs序+线段树) 链接:https://ac.nowcoder.com/acm/problem/15706 现在需要您来帮忙维护这个名册, ...

  9. 牛客网 2018年东北农业大学春季校赛 L题 wyh的天鹅

    链接:https://www.nowcoder.com/acm/contest/93/L来源:牛客网 时间限制:C/C++ 3秒,其他语言6秒空间限制:C/C++ 262144K,其他语言524288 ...

随机推荐

  1. 学习笔记 第十五章 JavaScript基础

    第15章   JavaScript基础 [学习重点] 了解JavaScript基础知识 熟悉常量和变量 能够使用表达式和运算符 正确使用语句 能够掌握数据类型和转换的基本方法 正确使用函数.对象.数组 ...

  2. 短视频SDK用于旅游行业

    超级简单易用的短视频SDK来自RDSDK.COM.锐动天地为开发者提供短视频编辑.视频直播.特效.录屏.编解码.视频转换,等多种解决方案,涵盖PC.iOS.Android多平台.以市场为导向,不断打磨 ...

  3. WordPress更改固定链接出现404

    新浪SAE的前端采用的是nginx,nginx是不识别.htaccess的. 最后学习了新浪SAE官方教程——应用配置模块 – AppConfig终于把问题解决! 1.修改你SAE SDK站点目录下的 ...

  4. 新奇:(nodejs兄弟)用HTML + FLASH +JS 也可以写桌面EXE。

    首先看下面这张图片,下面的所有界面都是用html代码实现的. 编程IDE:vb6.0 使用控件:WEBBROWSER 原理:使用olelib 让程序继承:IDocHostUIHandler 和 ICu ...

  5. Delphi win10 asssertion failure

    Delphi2007 原来安装在Win7 下 运行正常, 自从升级到Win10 ,新建工程运行然后关闭报错, 报错信息如下: ---------------------------bds.exe - ...

  6. win8怎么打开或关闭快速启动(进入BIOS前的设置)

    win8系统之后,系统添加了快速启动功能,这让Windows的启动速度快了不少.但是,任何事物有利有弊,相信不少人在进入BIOS或者重装系统时遇到了麻烦.接下来我们看看在win8及以上版本怎么打开或关 ...

  7. Python_高阶函数、装饰器(decorator)

    一.变量: Python支持多种数据类型,在计算机内部,可以把任何数据都看成一个“对象”,而变量就是在程序中用来指向这些数据对象的,对变量赋值就是把数据和变量给关联起来. 对变量赋值x = y是把变量 ...

  8. badblocks - 查询设备的坏区块

    语法(SYNPSIS) badblocks [ -svwnf ] [ -b block-size ] [ -c blocks_at_once ] [ -i input_file ] [ -o outp ...

  9. 【原】简单shell练习(二)

    1.查找awk # cat /etc/passwd |awk -F ':' 'BEGIN {print "name,shell"} {print $1","$7 ...

  10. SQL Server中 sysobjects、sysolumns、systypes

    1.sysobjects    系统对象表. 保存当前数据库的对象,如约束.默认值.日志.规则.存储过程等 在大多数情况下,对你最有用的两个列是Sysobjects.name和Sysobjects.x ...