C 给出一个m 此时有 四个数 分别为x k*x k*k*x k*k*k*x k大于1 x大于等于1 要求求出来一个最小的值n 使其满足 这四个数中的最大值小于n 这四个数可能的组数为m

可以看出这四个数递增 所以最大值必定是第四个

所以我们二分n 需要注意的是longlong可以定义到1e18 初始应当是l小于等于可能的最小值(0) r大于等于可能的最大值(1e18) 如果初始范围就定义错误的话 二分不会出现正确答案

在这里由于控制l=mid+1或者r=mid-1 这一类的时候 容易丢失mid 造成一些麻烦 所以采用了一种看起来比较暴力的写法 当满足judge==m时直接break出来 然后while控制变小

因为如果满足过judge 就一定不是-1

需要注意的是避免i*i*i爆int 提前初始化省时间

时间复杂度是二分(最大64 )*1e6

#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<map>
#include<math.h>
#include<queue>
using namespace std;
long long n,m;
long long a[1000050];
void init()
{
for(long long i=1;i<=1000000;i++)
{
a[i]=i*i*i;
}
}
long long judge(long long z)
{
long long res=0;
for(int i=2;i<=1000000;i++)
{
if(z/a[i]==0)
return res;
res+=(z/a[i]);
}
return res;
}
int main()
{
while(~scanf("%lld",&m))
{
init();
long long l=0;
long long r= 1e18+50000000;
long long mid;
while(l<=r)
{ mid=(l+r)>>1;
long long z=judge(mid);
if(z>m)
{
r=mid-1;
}
else if(z<m)
{
l=mid+1;
}
else break;
}
if(judge(mid)==m)
{
while(true)
{
mid--;
if(judge(mid)==m){
continue;
}
else {
printf("%lld\n",mid+1);
break;
}
}
} else printf("-1\n");
}
}

D 给出两个数组 求出满足条件的l r组数 max第一组a[l-r] = min第二组b[l-r]

比赛的时候去掉了线段树莫队rmq 因为如果抽象询问的话 最后是n*(n+1)/2次询问 n是2e5 太大

也想到过二分 因为看起来应该采用nlogn的办法 然而因为二分需要满足稳定的递增 就排除了

赛后看题解..居然真的是二分+rmq  记得那场cf感觉奇难 AB打完一个小时就过去了 怎么可能想出来二分+数据结构这种神奇的办法

这个算法里面 rmq的预处理是nlogn的 查询是1的 二分的查询也是常数的 所以总体是nlogn的

http://blog.csdn.net/Miracle_ma/article/details/51860149 这道题的思想和rmq模板都来自于这个博客

每次我们枚举i 以i作为左区间枚举右区间 满足max-min=0

第一次我们得到的是 最左的不满足的 第二次得到的是 最右的满足的 相减就是i做左区间的右区间范围

需要注意的是ans可能爆int

#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<math.h>
#include<map>
#include<queue>
#include<iostream>
#include<vector>
using namespace std;
int a[200050];
int b[200050];
int aa[200050][25];
int bb[200050][25];
int n;
void rmq_inita()
{
for(int i=0; i<n; i++) aa[i][0]=a[i];
for(int j=1; (1<<j)<=n; j++)
{
for(int i=0; i+(1<<j)-1<n; i++)
{
aa[i][j]=max(aa[i][j-1],aa[i+(1<<(j-1))][j-1]);
}
}
} void rmq_initb()
{
for(int i=0; i<n; i++) bb[i][0]=b[i];
for(int j=1; (1<<j)<=n; j++)
{
for(int i=0; i+(1<<j)-1<n; i++)
{
bb[i][j]=min(bb[i][j-1],bb[i+(1<<(j-1))][j-1]);
}
}
} int rmqa(int L,int R)
{
int k=0;
while((1<<(k+1))<=R-L+1) k++;
return max(aa[L][k],aa[R-(1<<k)+1][k]);
} int rmqb(int L,int R)
{
int k=0;
while((1<<(k+1))<=R-L+1) k++;
return min(bb[L][k],bb[R-(1<<k)+1][k]);
}
int main()
{
while(cin>>n)
{
for(int i = 0; i<n; i++)cin>>a[i];
for(int i = 0; i<n; i++)cin>>b[i];
rmq_inita();
rmq_initb();
long long int ans= 0;
for(int i=0; i<n; i++)
{
long long int res=0;
int l = i;
int r = n-1;
while(l<=r)
{
int mid = (l + r)>>1;
if(rmqa(i,mid)-rmqb(i,mid)<0)
{
l = mid + 1;
}
else r = mid - 1;
}
res= l;
l = i;
r = n-1;
while(l<=r)
{
int mid = (l + r)>>1;
if(rmqa(i,mid)-rmqb(i,mid)>0)
{
r = mid - 1;
}
else l = mid + 1;
}
ans += l-res;
}
printf("%lld\n",ans);
}
}

  

Codeforces Round #361 (Div. 2) C D的更多相关文章

  1. Codeforces Round #361 (Div. 2) C.NP-Hard Problem

    题目连接:http://codeforces.com/contest/688/problem/C 题意:给你一些边,问你能否构成一个二分图 题解:二分图:二分图又称作二部图,是图论中的一种特殊模型. ...

  2. Codeforces Round #361 (Div. 2) E. Mike and Geometry Problem 离散化 排列组合

    E. Mike and Geometry Problem 题目连接: http://www.codeforces.com/contest/689/problem/E Description Mike ...

  3. Codeforces Round #361 (Div. 2) D. Friends and Subsequences 二分

    D. Friends and Subsequences 题目连接: http://www.codeforces.com/contest/689/problem/D Description Mike a ...

  4. Codeforces Round #361 (Div. 2) C. Mike and Chocolate Thieves 二分

    C. Mike and Chocolate Thieves 题目连接: http://www.codeforces.com/contest/689/problem/C Description Bad ...

  5. Codeforces Round #361 (Div. 2) B. Mike and Shortcuts bfs

    B. Mike and Shortcuts 题目连接: http://www.codeforces.com/contest/689/problem/B Description Recently, Mi ...

  6. Codeforces Round #361 (Div. 2) A. Mike and Cellphone 水题

    A. Mike and Cellphone 题目连接: http://www.codeforces.com/contest/689/problem/A Description While swimmi ...

  7. Codeforces Round #361 (Div. 2) E. Mike and Geometry Problem 【逆元求组合数 && 离散化】

    任意门:http://codeforces.com/contest/689/problem/E E. Mike and Geometry Problem time limit per test 3 s ...

  8. Codeforces Round #361 (Div. 2) D

    D - Friends and Subsequences Description Mike and !Mike are old childhood rivals, they are opposite ...

  9. Codeforces Round #361 (Div. 2) C

    C - Mike and Chocolate Thieves Description Bad news came to Mike's village, some thieves stole a bun ...

  10. Codeforces Round #361 (Div. 2) B

    B - Mike and Shortcuts Description Recently, Mike was very busy with studying for exams and contests ...

随机推荐

  1. yii2.0 的数据的 改

    修改数据 /**     * 根据获取到的数据的id 去编辑对应的数据  controller层     */ //引入对应的model use app\models\About; //定义一个方法 ...

  2. 去除手机端触摸滑动事件ontouchmove

    window.ontouchmove=function(e){ e.preventDefault && e.preventDefault(); e.returnValue=false; ...

  3. Webstorm & PhpStorm

    WebStorm注册码 User Name: EMBRACE License Key: ===== LICENSE BEGIN ===== 24718-12042010 00001h6wzKLpfo3 ...

  4. [转] FastMM使用详解

    FastMM使用详解 一.引言      FastMM 是适用于delphi的第三方内存管理器,在国外已经是大名鼎鼎,在国内也有许多人在使用或者希望使用,就连 Borland 也在delphi2007 ...

  5. 利用TaskCompletionSource将EAP转换成TAP

        1.原始的异步方法的调用   我们来看个简单的例子,在这里演示调用 WebClient.DownloadStringAsync 方法(这个方法不是 TAP),然后由 WebClient.Dow ...

  6. BZOJ4171 : Rhl的游戏

    把第一行每个位置设成未知量,对于之后每一行,都可以用第一行的未知量线性表示. 那么只需要加上最后一行的$m$个方程,对于不能按的那$k$个位置也列出对应的方程. 用高斯消元判断是否有解即可,时间复杂度 ...

  7. BZOJ2320 : 最多重复子串

    本题就是求重复数最多的字典序最小的$runs$,如果重复数为1,那么做法显然,然后只考虑重复数大于1的情况. 从小到大枚举长度$len$,对于每个关键点$x=i\times len$,有且仅有一个长度 ...

  8. storm源码之storm代码结构【译】【转】

    [原]storm源码之storm代码结构[译]  说明:本文翻译自Storm在GitHub上的官方Wiki中提供的Storm代码结构描述一节Structure of the codebase,希望对正 ...

  9. mongodb新手入门,mongodb命令学习

    下面来总结一下mongodb新手入门的常用命令吧.要是您是mongodb新手,可以看下. 1,show dbs 查询mongodb里面的数据库列表 如果想查看当前连接在哪个数据库下面,可以直接输入db ...

  10. BZOJ2190 & 欧拉函数

    题意: 求1-n内互质数对个数 SOL: 裸欧拉函数,还有莫比乌斯反演的加速什么的,挖个坑. Code: /*============================================= ...