PROBLEM D. Alarm Clock

  OvO http://codeforces.com/contest/898/problem/D

  codeforces 898d

  从前往后枚举,放进去后不合法就拿出来,记录拿出来的次数

  中途每放进去一个数,会影响到一个区间,标记这个区间的首位(做差分,首+1,尾-1),同时维护这些标记的前缀和

#include <iostream>
#include <cstring>
#include <cmath>
#include <algorithm>
#include <cstdio> using namespace std; const int M=1e6+44; int n,m,k;
int s[M];
int sum[M],num[M]; int main()
{
int lst,ans=0;
scanf("%d%d%d",&n,&m,&k);
for(int i=1;i<=n;i++)
scanf("%d",&s[i]);
sort(s+1,s+n+1);
memset(sum,0,sizeof(sum));
lst=0;
for(int i=1;i<=n;i++)
{
for(int j=lst+1;j<=s[i];j++)
sum[j]+=sum[j-1];
lst=s[i];
if(sum[s[i]]-sum[max(0,s[i]-m)]+1>=k)
ans++;
else
sum[s[i]]++;
}
printf("%d\n",ans);
return 0;
}

  

PROBLEM E. Squares and not squares 

题 

  OvO http://codeforces.com/contest/898/problem/E

  codeforces 898e

  预处理出10000个左右的完全平方数,然后对于每个输入的数归类他们是否是完全平方数,并且算出各自的最小代价(二分之类的)

  然后根据代价排序,从小到大补足

#include <iostream>
#include <cstring>
#include <cmath>
#include <algorithm>
#include <cstdio>
#include <set> using namespace std; typedef long long ll; const ll M=2e5+44; struct Node
{
ll num,val;
} g[M],ng[M]; ll lg,lng;
ll n,m;
ll s[M];
ll p[M];
ll lp;
set<ll> se; bool cmp(Node a,Node b)
{
return a.val<b.val;
} void init()
{
se.clear();
lp=100000;
for(ll i=0;i<=lp;i++)
p[i]=1ll*i*i,se.insert(p[i]);
} int main()
{
ll tmp,ans;
init();
scanf("%I64d",&n);
lg=lng=0;
for(ll i=1;i<=n;i++)
{
scanf("%I64d",&s[i]);
if(se.find(s[i])==se.end())
{
ng[++lng].num=s[i];
tmp=upper_bound(p,p+lp+1,s[i])-p;
ng[lng].val=min(p[tmp]-s[i],s[i]-p[tmp-1]);
}
else
{
g[++lg].num=s[i];
if(s[i]==0) g[lg].val=2;
else g[lg].val=1;
}
}
sort(ng+1,ng+lng+1,cmp);
sort(g+1,g+lg+1,cmp);
m=n/2;
ans=0;
if(lng>m)
{
for(ll i=1;i<=lng-m;i++)
ans+=ng[i].val;
}
else
{
for(ll i=1;i<=lg-m;i++)
ans+=g[i].val;
}
printf("%I64d\n",ans);
return 0;
}

  

  

  

PROBLEM F. Restoring the Expression

  OvO http://codeforces.com/contest/898/problem/F

  codeforces 898f

  记三段为A,B,C,枚举C段的长度lc,分别判断la=lc-1,la=lc,lb=lc-1,lb=lc,这4种情况是否合法。

  判断的话,做个哈希差不多的东西用来判断加法结果是否正确(哈希sed=10),截断的部分会涉及到除法,用逆元处理。哈希判断正确之后真实值再判断一次

#include <iostream>
#include <cstring>
#include <cmath>
#include <cstdio>
#include <algorithm> using namespace std; const int M=1e6+44;
const int sed=10;
const int mod=1e9+7; int n;
char str[M];
int s[M];
int suf[M];
int bas[M],inv[M]; long long pr(int a, int b)
{
long long r=1,base=a;
while(b!=0)
{
if(b&1)
r=(r*base)%mod;
base=(base*base)%mod;
b>>=1;
}
return r;
} bool check(int la,int lb,int lc)
{
int sava=la,savb=lb,savc=lc;
if(la>lc || lb>lc || la<1 || lb<1 || lc<1) return false;
int lia=1,lib=la+1,lic=la+lb+1;
if((la>1 && s[lia]==0) || (lb>1 && s[lib]==0) || (lc>1 && s[lic]==0)) return false;
int ria=la,rib=la+lb,ric=la+lb+lc;
int vala,valb,valc,up=0,tmp;
while(lc>0)
{
if(la>0) vala=s[ria];
else vala=0;
if(lb>0) valb=s[rib];
else valb=0;
tmp=up+vala+valb;
up=tmp/10; tmp%=10;
if(tmp!=s[ric])
return false;
la--; lb--; lc--;
ria--; rib--; ric--;
}
if(up) return false;
for(int i=1;i<=n;i++)
{
printf("%d",s[i]);
if(i==sava) printf("+");
if(i==sava+savb) printf("=");
}
return true;
} int getval(int li,int ri)
{
int ret,tmp;
tmp=(0ll+suf[li]-suf[ri+1])%mod;
tmp=(1ll*tmp*inv[n-ri])%mod;
ret=(tmp%mod+mod)%mod;
return ret;
} bool solve(int la,int lb,int lc)
{
int sava=la,savb=lb,savc=lc;
if(la>lc || lb>lc || la<1 || lb<1 || lc<1) return false;
int lia=1,lib=la+1,lic=la+lb+1;
if((la>1 && s[lia]==0) || (lb>1 && s[lib]==0) || (lc>1 && s[lic]==0)) return false;
int ria=la,rib=la+lb,ric=la+lb+lc;
int vala,valb,valc;
vala=getval(lia,ria);
valb=getval(lib,rib);
valc=getval(lic,ric);
// cout<<la<<' '<<lb<<' '<<lc<<endl;
// cout<<vala<<' '<<valb<<' '<<valc%mod<<endl;
if((0ll+vala+valb)%mod==valc%mod && check(la,lb,lc))
return true;
else return false;
} int main()
{
scanf("%s",str+1);
n=strlen(str+1);
for(int i=1;i<=n;i++)
s[i]=str[i]-'0';
bas[0]=1;
for(int i=1;i<=n;i++)
bas[i]=1ll*bas[i-1]*sed%mod;
for(int i=0;i<=n;i++)
inv[i]=pr(bas[i],mod-2);
suf[n+1]=0;
for(int i=n;i>=1;i--)
suf[i]=(suf[i+1]+1ll*bas[n-i]*s[i]%mod)%mod;
for(int i=1;i<=n;i++)
{
if(solve(i-1,n-i-(i-1),i) || solve(i,n-i-i,i) || solve(n-i-(i-1),i-1,i) || solve(n-i-i,i,i))
return 0;
}
return 0;
}

  

Codeforces Round #451 (Div. 2) [ D. Alarm Clock ] [ E. Squares and not squares ] [ F. Restoring the Expression ]的更多相关文章

  1. Codeforces Round #451 (Div. 2) A B C D E

    Codeforces Round #451 (Div. 2) A Rounding 题目链接: http://codeforces.com/contest/898/problem/A 思路: 小于等于 ...

  2. Codeforces Round #451 (Div. 2)-898A. Rounding 898B.Proper Nutrition 898C.Phone Numbers(大佬容器套容器) 898D.Alarm Clock(超时了,待补坑)(贪心的思想)

    A. Rounding time limit per test 1 second memory limit per test 256 megabytes input standard input ou ...

  3. 【Codeforces Round #451 (Div. 2) D】Alarm Clock

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 尺取法+二分. 类似滑动窗口. 即左端点为l,右端点为r. 维护a[r]-a[l]+1总是小于等于m的就好. (大于m就右移左端点) ...

  4. Codeforces Round #451 (Div. 2) A. Rounding【分类讨论/易错】

    A. Rounding time limit per test 1 second memory limit per test 256 megabytes input standard input ou ...

  5. Codeforces Round #451 (Div. 2)

    水题场.... 结果因为D题看错题意,B题手贱写残了...现场只出了A,C,E A:水题.. #include<bits/stdc++.h> #define fi first #defin ...

  6. Codeforces Round #451 (Div. 2) B. Proper Nutrition【枚举/扩展欧几里得/给你n问有没有两个非负整数x,y满足x·a + y·b = n】

    B. Proper Nutrition time limit per test 1 second memory limit per test 256 megabytes input standard ...

  7. 【Codeforces Round #451 (Div. 2) A】Rounding

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 模拟 [代码] /* 1.Shoud it use long long ? 2.Have you ever test several ...

  8. 【Codeforces Round #451 (Div. 2) B】Proper Nutrition

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 可以直接一层循环枚举. 也可以像我这样用一个数组来存y*b有哪些. 当然.感觉这样做写麻烦了.. [代码] /* 1.Shoud i ...

  9. 【Codeforces Round #451 (Div. 2) C】Phone Numbers

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 用map<string,vector > dic;模拟就好. 后缀.翻转一下就变成前缀了. 两重循环剔除这种情况不输出就 ...

随机推荐

  1. 【转帖】Linux的桌面环境gnome、kde、xfce、lxde 等等使用比较

    Linux的桌面环境gnome.kde.xfce.lxde 等等使用比较 https://www.cnblogs.com/chenmingjun/p/8506995.html 文章目录 图形界面架起用 ...

  2. 微信小程序开放数据解密 AES-128-CBC 解密(C#版本)

    最近在开发小程序,需要跟微信服务端交互,微信敏感数据都有加密返回,需要在服务端接收进行解密后再返回给客户端小程序,今天就通过C# 进行数据的解密,官方下载下来是Node.C++.php等,就是没有C# ...

  3. ApplicationListener原理分析

    在 Nacos配置服务原理 文中结束时提到过通过发布 ApplicationListener 刷新事件完成 Context 中属性值的更新.那么本章我们一起分析 ApplicationListener ...

  4. django 路由层 伪静态网页 虚拟环境 视图层

    路由层 无名分组 有名分组 反向解析 路由分发 名称空间 伪静态网页 虚拟环境 视图层 JsonResponse FBV与CBV 文件上传 项目urls.py下面 from app01 import ...

  5. mysql在B-Tree上创建伪哈希索引

    构建哈希的过程 select过程 长字符串下,构建索引可通过自定义哈希作为索引,本人通过实验,在3百多个数据记录的下,性能效果很明显,完全不是一个等级.以下为索引前后几种情况对比 无索引的url:直接 ...

  6. ELK-全过程搭建

    环境说明:软件包我都 给你们放/usr/local/src/elk目录下安装目录都放在/usr/local/下数据都放在/data0/elk/目录下日志都放在/data0/logs/elk目录下系统 ...

  7. 在Windows平台上运行Tomcat

    从之前的学习中知道,可以调用Bootstrap类将Toomcat作为一个独立的应用程序来运行,在Windows平台上,可以调用startup.bat批处理文件来启动Tomcat,或运行shutdown ...

  8. vs2010 回车、退格键等不能用

    有时候在vs2010中,突然回退键.回车键.方向键就用不了了,百度一堆方法,最后找到按Alt+Enter,就可以用了.

  9. BZOJ4241历史研究题解--回滚莫队

    题目链接 https://www.lydsy.com/JudgeOnline/problem.php?id=4241 分析 这题就是求区间权值乘以权值出现次数的最大值,一看莫队法块可搞,但仔细想想,莫 ...

  10. 豆瓣网post 爬取带验证码

    # -*- coding: utf- -*- import scrapy import requests from ..bao.jiema import get_number fromdata = { ...