cf1191 解题报告

A-简单模拟

脑内算出来让计算机输出

#include <bits/stdc++.h>
#define ll long long
using namespace std;
int main() {
int x;
cin>>x;
if(x%4==0) return puts("1 A"),0;
if(x%4==1) return puts("0 A"),0;
if(x%4==2) return puts("1 B"),0;
if(x%4==3) return puts("2 A"),0;
return 0;
}

B-细节模拟

脑内算出来让计算机输出。wa了几发、、、

#include <bits/stdc++.h>
#define ll long long
using namespace std;
int n;
string a[4];
int main() {
cin>>a[1]>>a[2]>>a[3];
sort(a+1,a+1+3);
if(a[1]==a[2]&&a[2]==a[3]) return puts("0"),0;
if(a[1][1]==a[2][1] and a[1][1]==a[3][1]) {
int x=a[1][0]-'0',y=a[2][0]-'0',z=a[3][0]-'0';
int b[44];
b[1]=x,b[2]=y,b[3]=z;
sort(b+1,b+1+3);
if(b[1]+1==b[2]&&b[2]+1==b[3]) return puts("0"),0;
}
int x=a[1][0]-'0',y=a[2][0]-'0',z=a[3][0]-'0';
if(a[1][1]==a[2][1])
if(abs(x-y)<=2) return puts("1"),0;
if(a[1][1]==a[3][1])
if(abs(x-z)<=2) return puts("1"),0;
if(a[2][1]==a[3][1])
if(abs(y-z)<=2) return puts("1"),0;
puts("2");
return 0;
}

C-模拟

每次暴力模拟就行,(a[l]-l+1)%k为当前在块内的初始位置。

#include <bits/stdc++.h>
#define int long long
using namespace std;
const int N=1e5+7;
int n,a[N],m,k;
signed main() {
cin>>n>>m>>k;
for(int i=1;i<=m;++i) cin>>a[i];
sort(a+1,a+1+m);
int ans=0,l=1;
while(l<=m) {
int j=(a[l]-l+1)%k;
if(!j) j=k;
while(j+(a[l+1]-a[l])<=k&&l<=m) l++,j+=a[l]-a[l-1];
l++,ans++;
}
cout<<ans;
return 0;
}

D-博弈

一条线上有n个点,点点之间不能占同一个位置。

先把开始就输的结果判掉。

之后的局面就要是0~n-1的排列了。

博弈是真的不会o(╥﹏╥)o

#include <bits/stdc++.h>
#define int long long
using namespace std;
const int N=1e5+7;
int n,a[N],sum;
signed main() {
cin>>n;
for(int i=1;i<=n;++i) cin>>a[i],sum+=a[i];
sort(a+1,a+1+n);
int flag=0;
for(int i=1;i<n;++i)
if(a[i]==a[i+1])
if(a[i]==0||(i>1&&a[i-1]+1==a[i])||++flag>1)
return puts("cslnb"),0;
int las=sum-n*(n-1)/2;
if(las&1) puts("sjfnb");
else puts("cslnb");
return 0;
}

E-博弈

咕咕咕

F-数据结构

离散化后,枚举a的位置。

然后考虑一行的贡献。

把此行及其以上的点压缩到数轴上。

贡献显然产生在有此行的点的区间内,计算出来区间个数就是此行的贡献。

因为不在此行的话,上面已经统计过了。

具体统计的话,就是总的区间-不包含的小区间。

统计用BIT就OK。

#include <bits/stdc++.h>
#define ll long long
using namespace std;
const int N=2e5+7;
int n,b[N],lsh[2][N];
struct node {
int first,second;
bool operator < (const node &b) const {
return first==b.first?second<b.second:first>b.first;
}
}a[N];
namespace BIT {
int sum[N];
int lowbit(int x) {return x&-x;}
void add(int x) {for(int i=x;i<=n;i+=lowbit(i)) sum[i]++;}
int query(int x) {int ans=0;for(int i=x;i>=1;i-=lowbit(i)) ans+=sum[i];return ans;}
}
int main() {
scanf("%d",&n);
for(int i=1;i<=n;++i) {
scanf("%d%d",&a[i].second,&a[i].first);
lsh[0][i]=a[i].first;
lsh[1][i]=a[i].second;
}
sort(lsh[0]+1,lsh[0]+1+n);
sort(lsh[1]+1,lsh[1]+1+n);
int len[2];
len[0]=unique(lsh[0]+1,lsh[0]+1+n)-lsh[0]-1;
len[1]=unique(lsh[1]+1,lsh[1]+1+n)-lsh[1]-1;
for(int i=1;i<=n;++i) {
a[i].first=lower_bound(lsh[0]+1,lsh[0]+1+len[0],a[i].first)-lsh[0];
a[i].second=lower_bound(lsh[1]+1,lsh[1]+1+len[1],a[i].second)-lsh[1];
}
sort(a+1,a+1+n);
ll ans=0;
for(int i=len[0],now=0,tmp=0,gs=0;i>=1;--i) {
int las=0;
while(a[now+1].first==i&&now+1<=n) {
now++;
tmp=BIT::query(a[now].second-1)-BIT::query(las);
ans-=1LL*tmp*(tmp+1)/2;
if(!b[a[now].second]) {
BIT::add(a[now].second);
b[a[now].second]=1;
gs++;
}
las=a[now].second;
}
tmp=gs-BIT::query(las);
ans-=1LL*tmp*(tmp+1)/2;
ans+=1LL*gs*(gs+1)/2;
}
cout<<ans<<"\n";
return 0;
}

cf1191 解题报告的更多相关文章

  1. CH Round #56 - 国庆节欢乐赛解题报告

    最近CH上的比赛很多,在此会全部写出解题报告,与大家交流一下解题方法与技巧. T1 魔幻森林 描述 Cortana来到了一片魔幻森林,这片森林可以被视作一个N*M的矩阵,矩阵中的每个位置上都长着一棵树 ...

  2. 二模13day1解题报告

    二模13day1解题报告 T1.发射站(station) N个发射站,每个发射站有高度hi,发射信号强度vi,每个发射站的信号只会被左和右第一个比他高的收到.现在求收到信号最强的发射站. 我用了时间复 ...

  3. BZOJ 1051 最受欢迎的牛 解题报告

    题目直接摆在这里! 1051: [HAOI2006]受欢迎的牛 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 4438  Solved: 2353[S ...

  4. 习题:codevs 2822 爱在心中 解题报告

    这次的解题报告是有关tarjan算法的一道思维量比较大的题目(真的是原创文章,希望管理员不要再把文章移出首页). 这道题蒟蒻以前做过,但是今天由于要复习tarjan算法,于是就看到codevs分类强联 ...

  5. 习题:codevs 1035 火车停留解题报告

    本蒟蒻又来写解题报告了.这次的题目是codevs 1035 火车停留. 题目大意就是给m个火车的到达时间.停留时间和车载货物的价值,车站有n个车道,而火车停留一次车站就会从车载货物价值中获得1%的利润 ...

  6. 习题: codevs 2492 上帝造题的七分钟2 解题报告

    这道题是受到大犇MagHSK的启发我才得以想出来的,蒟蒻觉得自己的代码跟MagHSK大犇的代码完全比不上,所以这里蒟蒻就套用了MagHSK大犇的代码(大家可以关注下我的博客,友情链接就是大犇MagHS ...

  7. 习题:codevs 1519 过路费 解题报告

    今天拿了这道题目练练手,感觉自己代码能力又增强了不少: 我的思路跟别人可能不一样. 首先我们很容易就能看出,我们需要的边就是最小生成树算法kruskal算法求出来的边,其余的边都可以删掉,于是就有了这 ...

  8. NOIP2016提高组解题报告

    NOIP2016提高组解题报告 更正:NOIP day1 T2天天爱跑步 解题思路见代码. NOIP2016代码整合

  9. LeetCode 解题报告索引

    最近在准备找工作的算法题,刷刷LeetCode,以下是我的解题报告索引,每一题几乎都有详细的说明,供各位码农参考.根据我自己做的进度持续更新中......                        ...

随机推荐

  1. Python开发【第十二篇】python作用域和global nonlocal

    python的作用域 作用域也叫名字空间,是访问变量时查找变量名的范围空间 python中的四个作用域 LEGB 作用域 英文解释 英文缩写 局部作用域 Local(function) L 外部嵌套函 ...

  2. DotnetSpider爬虫简单示例 net core

    文章地址 https://blog.csdn.net/sD7O95O/article/details/78097556 安装爬虫框架  NUGET 安装DotnetSpider 创建HTTP协议数据包 ...

  3. 配置 Log4j 以便查看 MyBatis 操作数据库的过程

    在 src/main/resources中添加 log4j.properties 配置文件 ,输入如下内 容.#全局面已直 log4j .rootLogger=ERROR, stdout #MyBat ...

  4. nodejs vue的安装

    1.https://nodejs.org/en/ 下载最新版nodejs 2.安装好后win+R输入cmd(管理员权限键入):node -v(node版本)npm -v(npm版本)查看版本号,如图所 ...

  5. Matlab解释器模式

    解释器模式(Interperter),给定一个语言,定义一个语言的文法,并且建立一个解释器来解释该语言中的句子,实际开发中EL表达式或者正则表达式的解释器就是采用这种设计模式.其模式结构如下图.本文使 ...

  6. echarts的地图省份颜色自适应变化

    在使用echarts的地图的时候省份的颜色可能随着数据的多少显示不同的颜色,但是当后台返回的数据的变化较大时可能就不好控制了,所以需要设置根据后台的数据进行自适应 将后台返回的数据中的value放入一 ...

  7. Swaks绕过SPF验证进行邮件伪造

    0x00 swaks简介 Swaks是一个功能强大,灵活,可编写脚本,面向事务的SMTP测试工具,由John Jetmore编写和维护. 目前Swaks托管在私有svn存储库中.官方项目页面是http ...

  8. C#的静态类

    静态类 静态类与非静态类的重要区别在于静态类不能实例化,也就是说,不能使用 new 关键字创建静态类类型的变量.在声明一个类时使用static关键字,具有两个方面的意义:首先,它防止程序员写代码来实例 ...

  9. JAVA Coder 的《深入分析Java Web 技术内幕》读书笔记

    本文基于<深入分析Java Web 技术内幕> <深入分析Java Web 技术内幕>,作者是 许令波,电子工业出版社.本文只是记录书本当中的精彩部分,作个人回顾和技术分享,请 ...

  10. Mac原型动画设计软件Drama创建3D图层的注意事项,你知道吗?

    Drama创建3D图层的注意事项:要跨层保留3D空间,可以使用组.它们具有保留子图层和嵌套组的3D空间的特殊功能. Drama支持通过在三维空间中定位和旋转2D图层来创建3D内容.要在3D空间中定位图 ...