[CF707 Div2, A ~ D]
(相信进这个博客的人,都已经看过题目了,不再赘述)
这把打小号打到了\(484\),\(rating + 636\)
\(A\)
考虑进行模拟就行了,说白了这是一个英语阅读题
// code by Dix_
#include<bits/stdc++.h>
#define ll long long
inline ll read(){
char C=getchar();
ll N=0 , F=1;
while(('0' > C || C > '9') && (C != '-')) C=getchar();
if(C == '-') F=-1 , C=getchar();
while('0' <= C && C <= '9') N=(N << 1)+(N << 3)+(C - 48) , C=getchar();
return F*N;
}
ll T,a[200],b[200],t[200],now;
int main(){
scanf("%lld",&T);
while(T -- ){
ll n;
scanf("%lld",&n);
for(int i = 1;i <= n;++i){
scanf("%lld%lld",&a[i],&b[i]);
}
for(int i = 1;i <= n;++i)
scanf("%lld",&t[i]);
ll now = t[1] + a[1];
for(int i = 1;i <= n - 1;++i){
now += std::ceil(((double)b[i] - a[i]) / 2.0);
now = std::max(now,b[i]);
now += (a[i + 1] - b[i] + t[i + 1]);
}
std::cout<<now<<std::endl;
}
}
\(B\)
考虑进行一个差分处理,再还原原数组
// code by Dix_
#include<bits/stdc++.h>
#define ll long long
inline ll read(){
char C=getchar();
ll N=0 , F=1;
while(('0' > C || C > '9') && (C != '-')) C=getchar();
if(C == '-') F=-1 , C=getchar();
while('0' <= C && C <= '9') N=(N << 1)+(N << 3)+(C - 48) , C=getchar();
return F*N;
}
ll t,cnt[200010],now;
int main(){
scanf("%lld",&t);
while(t -- ){
ll n;
scanf("%lld",&n);
for(int i = 0;i <= n + 1;++i)
cnt[i] = 0;
for(int i = 1;i <= n;++i){
ll x = read();
cnt[i + 1] -= 1;
cnt[std::max((ll)0,i - x + 1)] += 1;
}
for(int i = 1;i <= n;++i){
cnt[i] = cnt[i - 1] + cnt[i];
if(cnt[i])
std::cout<<1<<" ";
else
std::cout<<0<<" ";
}
puts("");
}
}
\(C\)
大毒瘤题,想了\(1h\)的做法最后和暴力一样写
观察\(n\)的范围和值域,我们发现在\(n\)较大时,点对数\((n * (n - 1)) / 2 > 2 * |V|\),所以必定有解,那么我们利用这个来进行一个抽屉原理证明
可以证明暴力写法复杂度是对的
// code by Dix_
#include<bits/stdc++.h>
#define ll long long
inline ll read(){
char C=getchar();
ll N=0 , F=1;
while(('0' > C || C > '9') && (C != '-')) C=getchar();
if(C == '-') F=-1 , C=getchar();
while('0' <= C && C <= '9') N=(N << 1)+(N << 3)+(C - 48) , C=getchar();
return F*N;
}
ll n;
std::map<ll,int>QWQ;
std::map<ll,int>QAQ;
ll num[200005];
int main(){
scanf("%lld",&n);
for(int i = 1;i <= n;++i)
scanf("%lld",&num[i]);
for(int i = 1;i <= n;++i)
for(int j = i + 1;j <= n;++j){
ll sum = num[i] + num[j];
if(QWQ.count(sum))
if(QWQ[sum] != i && QAQ[sum] != j && QWQ[sum] != j && QAQ[sum] != i){
puts("YES");
std::cout<<QWQ[sum]<<" "<<QAQ[sum]<<" "<<i<<" "<<j<<std::endl;
return 0;
}
QWQ[sum] = i,QAQ[sum] = j;
}
puts("NO");
}
\(D\)
考虑一个周期内有多少个不同的,再二分求出后面零散的天数
\(Excrt\)不会,得去学,这题是后来补的
#include<vector>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
typedef long long LL;
typedef unsigned long long ULL;
const int N=1e6+5;
LL muler(LL x,LL k,LL MOD)
{
LL res=0; x=(x%MOD+MOD)%MOD; k=(k%MOD+MOD)%MOD;
while(k) {
if(k&1) res=(res+x)%MOD;
x=(x+x)%MOD; k>>=1;
}
return res%MOD;
}
LL power(LL x,LL k,LL MOD)
{
LL res=1; x%=MOD;
while(k) {
if(k&1) res=muler(res,x,MOD);
x=muler(x,x,MOD); k>>=1;
}
return res%MOD;
}
LL exgcd(LL a,LL b,LL& x,LL& y)
{
if(b==0) {
x=1; y=0;
return a;
}
LL z=exgcd(b,a%b,y,x);
y-=a/b*x;
return z;
}
LL inv(LL x,LL p)
{
LL y,z; exgcd(x,p,y,z);
return (y%p+p)%p;
}
LL excrt(int n,LL b[],LL a[])
{
LL m=a[1],ans=b[1];
for(int i=2;i<=n;i++) {
LL y,z,d=exgcd(m,a[i],y,z);
if((b[i]-ans)%d!=0) return -1;
y=muler(y,(b[i]-ans)/d,a[i]/d);
ans+=y*m;
m=a[i]/d*m;
ans=(ans%m+m)%m;
}
return ans;
}
LL gcd(LL a,LL b)
{
if(b==0) return a;
else return gcd(b,a%b);
}
LL lcm(LL a,LL b) { return a/gcd(a,b)*b; }
int n,m;
LL kth;
int a[N],b[N],c[N];
LL A[N],B[N];
vector<LL> v;
LL calc(LL day)
{
// cerr<<day<<" "<<day-(upper_bound(v.begin(),v.end(),day)-v.begin())<<endl;
if(day<=0) return 0;
else return day-(upper_bound(v.begin(),v.end(),day)-v.begin());
}
int main()
{
// freopen("1.in","r",stdin);
int i,j;
LL x;
scanf("%d%d%lld",&n,&m,&kth);
for(i=0;i<n;i++) scanf("%d",&a[i]);
for(i=0;i<m;i++) scanf("%d",&b[i]);
memset(c,-1,sizeof c);
for(i=0;i<n;i++) c[a[i]]=i;
for(i=0;i<m;i++) {
if(~c[b[i]]) {
j=c[b[i]];
A[1]=n; A[2]=m;
B[1]=j; B[2]=i;
x=excrt(2,B,A);
if(x==-1) continue;
v.push_back(x+1);
// cerr<<x<<endl;
}
}
sort(v.begin(),v.end());
LL times=lcm(n,m)-v.size();
LL turns=(kth-1)/times;
kth-=turns*times;
LL L=-1,R=lcm(n,m),mid;
while(L+1<R) {
mid=(L+R)>>1;
if(calc(mid)>=kth) R=mid;
else L=mid;
}
printf("%lld\n",turns*lcm(n,m)+R);
return 0;
}
[CF707 Div2, A ~ D]的更多相关文章
- bc#54 div2
用小号做的div2 A:竟然看错了排序顺序...白白WA了两发 注意读入一整行(包括空格):getline(cin,st) [gets也是资瓷的 #include<iostream> us ...
- $('div a') 与$('div>a'),.div+.div2与.div~.div2
$('div a'):div标签下所有层次a元素的jquery对象 $('div>a'):div标签下子元素层次a元素的jquery对象 <body> <div class=' ...
- SRM 657 DIV2
-------一直想打SRM,但是感觉Topcoder用起来太麻烦了.题目还是英文,不过没什么事干还是来打一打好了.但是刚注册的号只能打DIV2,反正我这么弱也只适合DIV2了.. T1: 题目大意: ...
- CodeForces Round 192 Div2
This is the first time I took part in Codeforces Competition.The only felt is that my IQ was contemp ...
- Codeforce Round #211 Div2
真的是b到不行啊! 尼玛C题一个这么简单的题目没出 aabbccddee 正确的是aabccdee 我的是 aabcdee 硬是TM的不够用,想半天还以为自己的是对的... A:题... B:题. ...
- Topcoder srm 632 div2
脑洞太大,简单东西就是想复杂,活该一直DIV2; A:水,基本判断A[I]<=A[I-1],ANS++; B:不知道别人怎么做的,我的是100*N*N;没办法想的太多了,忘记是连续的数列 我们枚 ...
- TopCoder 603 div1 & div2
div2 250pts MiddleCode 题意:s串长度为奇数时,将中间字符取掉并添加到t末尾:长度为偶数时,将中间两个较小的字符取掉并添加到末尾. 分析:直接做,学习了一下substr(s, p ...
- TopCoder 649 div1 & div2
最近一场TC,做得是在是烂,不过最后challenge阶段用一个随机数据cha了一个明显错误的代码,最后免于暴跌rating,还涨了一点.TC题目质量还是很高的,非常锻炼思维,拓展做题的视野,老老实实 ...
- 220 DIV2 B. Inna and Nine
220 DIV2 B. Inna and Nine input 369727 output 2 input 123456789987654321 output 1 题意:比如例子1:369727--& ...
随机推荐
- Hive面试题整理(一)
1.Hive表关联查询,如何解决数据倾斜的问题?(☆☆☆☆☆) 1)倾斜原因:map输出数据按key Hash的分配到reduce中,由于key分布不均匀.业务数据本身的特.建表时考虑不周.等原因 ...
- 这样学BAT必面之软件设计原则,还不会就是我的问题
学习设计原则是学习设计模式的基础.在实际开发过程中,并不要求所有代码都遵循设计原则,我们要考虑人力.时间.成本.质量,不能刻意追求完美,但要在适当的场景遵循设计原则,这体现的是一种平衡取舍,可以帮助我 ...
- 【数据结构与算法Python版学习笔记】树——平衡二叉搜索树(AVL树)
定义 能够在key插入时一直保持平衡的二叉查找树: AVL树 利用AVL树实现ADT Map, 基本上与BST的实现相同,不同之处仅在于二叉树的生成与维护过程 平衡因子 AVL树的实现中, 需要对每个 ...
- 80. 删除有序数组中的重复项 II
题目 给你一个有序数组 nums ,请你原地删除重复出现的元素(不需要考虑数组中超出新长度后面的元素),使每个元素最多出现两次 ,返回删除后数组的新长度. 不要使用额外的数组空间,你必须在原地修改输入 ...
- 同人逼死官方系列!从 DDC 嗅探器到 sddc_sdk_lib 的数据解析
从 DDC 嗅探器到 sddc_sdk_lib 的数据解析 之前的 DDC 协议介绍 主要讲了设备加入.退出以及维持设备状态,而 SDK框架 sddc_sdk_lib 解析 主要讲了 SDK 库的结构 ...
- 还在用canvas画格子吗?文字烟花效果更不错噢
大家好,我是小丞同学,一名前端爱好者 欢迎访问博主的个人网站:一口奶盖 "在人间贩卖声音 等凑够满天星辰 放烟花给你看" 上次的烟花有些许平淡,这次来放大招了,让你的名字在天空绽放 ...
- 20191310李烨龙Linux C语言编程基础
Linux C语言编程基础 任务详情 0. 基于Ubuntu或OpenEuler完成下面的任务(OpenEuler有加分) 1. 选择教材第二章的一节进行编程基础练习(2.10,2.11,2.12,2 ...
- DeWeb第1个通用化模块:登录模块,仅需要修改一个配置文件即可实现登录功能
演示: https://delphibbs.com/login.dw 开发环境和源代码 https://gitee.com/xamh/dewebsdk 效果图: 配置方法: 在Runtime目录中放一 ...
- ☕【Java技术指南】「序列化系列」深入挖掘FST快速序列化压缩内存的利器的特性和原理
FST的概念和定义 FST序列化全称是Fast Serialization Tool,它是对Java序列化的替换实现.既然前文中提到Java序列化的两点严重不足,在FST中得到了较大的改善,FST的特 ...
- Java Logback简易教程
本作品采用知识共享署名-非商业性使用 4.0 国际许可协议进行许可. 一.前言 本文以一个简单的项目为例,一步步展示logback的同步和异步配置方法,并且配置的日志要求满足阿里巴巴Java开发手册- ...