传送门

A - Beginner

#include <bits/stdc++.h>
#define ll long long
using namespace std;
int main() {
//freopen("in.txt","r",stdin);
int n,r;
scanf("%d%d",&n,&r);
if(n>=) printf("%d\n",r);
else printf("%d\n",r+*(-n));
return ;
}

A.cpp

B - Digits

#include <bits/stdc++.h>
#define ll long long
using namespace std;
int main() {
//freopen("in.txt","r",stdin);
int n,k,ans=;
scanf("%d%d",&n,&k);
while(n) {
n/=k;
ans++;
}
printf("%d\n",ans);
return ;
}

B.cpp

C - Rally

题意:在一条直线上,有N个人,分别在Xi位置上,要求找一点使得N个人到该点的距离平方和最小,并输出距离平方和。

数据范围:$1 \leq N,Xi \leq 100$

题解:暴力枚举每一个1~100每个位置即可。

#include <bits/stdc++.h>
#define ll long long
using namespace std;
const int N=;
int a[N];
int main() {
//freopen("in.txt","r",stdin);
int n,ans=1e9;
scanf("%d",&n);
for(int i=,x;i<n;i++) {
scanf("%d",&a[i]);
}
for(int i=;i<=;i++) {
int s=;
for(int j=;j<n;j++) {
s+=(a[j]-i)*(a[j]-i);
}
ans=min(ans,s);
}
printf("%d\n",ans);
return ;
}

C.cpp

D - Bouquet

题意:有n种不同的花,每种一朵,要求至少取1朵但,不能取a朵或b朵花,求能取得方案数(mod 1e9+7)。

数据范围:$2 \leq n \leq 10^{9},1 \leq a < b \leq min(n,2\times 10^{5})$

题解:总方案数-取a朵-取b朵-不取。即为 $2^{n}-C_{n}^{a}-C_{n}^{b}-1$。

#include <bits/stdc++.h>
#define ll long long
using namespace std;
const int MD=1e9+;
int quick_pow(int x,int y) {
int ans=;
while(y) {
if(y&) ans=1LL*ans*x%MD;
y>>=;
x=1LL*x*x%MD;
}
return ans;
}
void add(int &x,int y) {
x+=y;
if(x>=MD) x-=MD;
if(x<) x+=MD;
}
int main() {
//freopen("in.txt","r",stdin);
int n,a,b;
scanf("%d%d%d",&n,&a,&b);
int ans=quick_pow(,n),s=;
add(ans,-);
for(int i=;i<=b;i++) {
s=1LL*s*(n-i+)%MD,s=1LL*s*quick_pow(i,MD-)%MD;
if(i==a) add(ans,-s);
if(i==b) add(ans,-s);
}
printf("%d\n",ans);
return ;
}

D.cpp

E - Roaming

题意:有n个房间,每个房间初始有一个人,每次移动可将一个人移到另一个房间,求k次移动后n个房间的状态数。

数据范围:$3 \leq n \leq 2\times 10^{5},2 \leq k \leq 10^{9}$

题解:考虑房间人数为0的数量。

1.没有房间的人数为0的移法:把1移到2,然后2~3来回移动k-2次,最后在移回1。

2.有且只有一个房间的人数为0的移法:把1移到其它房间,然后在其它房间任意移动。

3.超过一个房间的人数为0的移法:结合上面两种移法即可。

枚举0的个数i,然后就是将i个人分到n-i的房间的子问题。

即为:$\sum_{0}^{min(k,n-1)}C_{n}^{i}*C_{n-1}^{i}$

#include <bits/stdc++.h>
#define ll long long
using namespace std;
const int N=4e5+;
const int MD=1e9+;
int f[N],inv[N];
int quick_pow(int x,int y) {
int ans=;
while(y) {
if(y&) ans=1LL*ans*x%MD;
y>>=;
x=1LL*x*x%MD;
}
return ans;
}
int C(int n,int m) {
return 1LL*f[n]*inv[m]%MD*inv[n-m]%MD;
}
void add(int &x,int y) {
x+=y;
if(x>=MD) x-=MD;
}
void init() {
f[]=;
for(int i=;i<N;i++) f[i]=1LL*f[i-]*i%MD;
inv[N-]=quick_pow(f[N-],MD-);
for(int i=N-;i>=;i--) inv[i]=1LL*inv[i+]*(i+)%MD;
}
int main() {
//freopen("in.txt","r",stdin);
init();
int n,k,ans=;
scanf("%d%d",&n,&k);
k=min(k,n-);
for(int i=;i<=k;i++) {
add(ans,1LL*C(n,i)*C(n-,i)%MD);
}
printf("%d\n",ans);
return ;
}

E.cpp

F - Modularness

题意:有k个非负整数di,q个查询,每次查询给三个整数n,x,m,构造出一个长度为n的序列,其中:

$a_{0}=x,a_{i}=a_{i-1}+d_{(i-1) \bmod k}$,输出存在多少个下标i(0<=i<n-1)满足$a_{i} \bmod m <a_{i+1}\bmod m$。

数据范围:$1 \leq k,q \leq 5000,0 \leq di,xi \leq 10^{9},2 \leq ni,mi \leq 10^{9}$

题解:总数 - $a_{i} \bmod m =a_{i+1}\bmod m$的数目 - $a_{i} \bmod m >a_{i+1}\bmod m$的数目。

可以先将di对m取模,这样di是一个小于m的数。

1.$a_{i} \bmod m =a_{i+1}\bmod m:di=0$

2.$a_{i} \bmod m >a_{i+1}\bmod m:\left \lfloor \frac{a_{i}}{m} \right \rfloor=\left \lfloor \frac{a_{i+1}}{m} \right \rfloor-1$

1可以很轻易的算出,2等价于$\left \lfloor \frac{a_{n-1}}{m} \right \rfloor - \left \lfloor \frac{a_{0}}{m} \right \rfloor$。

#include <bits/stdc++.h>
#define ll long long
using namespace std;
const int N=5e3+;
int d[N],t[N],k,q;
ll cal(int n,int x,int m) {
ll s=;
for(int i=;i<k;i++) {
t[i]=d[i]%m;
if(t[i]==) t[i]=m;
s+=t[i];
}
ll ans=x+s*((n-)/k);
for(int i=;i<(n-)%k;i++) {
ans+=t[i];
}
return n--(ans/m-x/m);
}
int main() {
//freopen("in.txt","r",stdin);
scanf("%d%d",&k,&q);
for(int i=;i<k;i++) {
scanf("%d",&d[i]);
}
for(int i=,n,x,m;i<q;i++) {
scanf("%d%d%d",&n,&x,&m);
printf("%lld\n",cal(n,x,m));
}
return ;
}

F.cpp

AtCoder Beginner Contest 156的更多相关文章

  1. AtCoder Beginner Contest 100 2018/06/16

    A - Happy Birthday! Time limit : 2sec / Memory limit : 1000MB Score: 100 points Problem Statement E8 ...

  2. AtCoder Beginner Contest 052

    没看到Beginner,然后就做啊做,发现A,B太简单了...然后想想做完算了..没想到C卡了一下,然后还是做出来了.D的话瞎想了一下,然后感觉也没问题.假装all kill.2333 AtCoder ...

  3. AtCoder Beginner Contest 053 ABCD题

    A - ABC/ARC Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement Smeke has ...

  4. AtCoder Beginner Contest 136

    AtCoder Beginner Contest 136 题目链接 A - +-x 直接取\(max\)即可. Code #include <bits/stdc++.h> using na ...

  5. AtCoder Beginner Contest 137 F

    AtCoder Beginner Contest 137 F 数论鬼题(虽然不算特别数论) 希望你在浏览这篇题解前已经知道了费马小定理 利用用费马小定理构造函数\(g(x)=(x-i)^{P-1}\) ...

  6. AtCoder Beginner Contest 076

    A - Rating Goal Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement Takaha ...

  7. AtCoder Beginner Contest 079 D - Wall【Warshall Floyd algorithm】

    AtCoder Beginner Contest 079 D - Wall Warshall Floyd 最短路....先枚举 k #include<iostream> #include& ...

  8. AtCoder Beginner Contest 064 D - Insertion

    AtCoder Beginner Contest 064 D - Insertion Problem Statement You are given a string S of length N co ...

  9. AtCoder Beginner Contest 075 D - Axis-Parallel Rectangle【暴力】

    AtCoder Beginner Contest 075 D - Axis-Parallel Rectangle 我要崩溃,当时还以为是需要什么离散化的,原来是暴力,特么五层循环....我自己写怎么都 ...

随机推荐

  1. Java List集合的介绍与常用方法

    List接口的介绍 List接口简介: java.util.List接口继承自Collection接口,是单列集合的一个重要分支,习惯性地会将实现了List接口的对象称为List集合. 在List集合 ...

  2. jqGrid以setGridParam方式postData,包含历史数据的问题

    系统在使用jqGrid时,如果某些页面的查询项是复选框,后台是数组接收的,就会出现传值不正确问题. 1.项目中某查询页面存在的复选框:待处理S1,正在处理S2,已处理S3: 使用jqGrid提交查询数 ...

  3. 头条一面竟然问我Maven?

    maven package和maven install 有什么区别? 你常用的maven命令有哪些? <dependencyManagement> 是干什么的? 还有用过其它构建工具吗? ...

  4. 异数OS国产CPU平台移植项目需求分析

    异数OS国产CPU平台移植项目需求分析 目录 异数OS国产CPU平台移植项目需求分析 项目立项背景 项目需求分析 异数OS性能指标简介 1.TCP协议栈性能测试 2.异数OS-织梦师-水母 消息队列性 ...

  5. [bzoj3244] [洛谷P1232] [Noi2013] 树的计数

    Description 我们知道一棵有根树可以进行深度优先遍历(DFS)以及广度优先遍历(BFS)来生成这棵树的DFS序以及BFS序.两棵不同的树的DFS序有可能相同,并且它们的BFS序也有可能相同, ...

  6. 【javaScript】报getElementId()为Null的错误

    若JavaScript代码写在<head>块中,若是javaScript,写JavaScript代码写在里面 window.οnlοad=function(){ js代码内容 } 若是jq ...

  7. 正斜杠(" / ")和反斜杠(" \ ")的区别

    反斜杠“\”是电脑出现了之后为了表示程序设计里的特殊含义才发明的专用标点.所以除了程序设计领域外,任何地方都不应该使用反斜杠. 如何区分正反斜杠 英语:"/" 英文是forward ...

  8. 2015年3月26日 - Javascript MVC 框架DerbyJS DerbyJS 是一个 MVC 框架,帮助编写实时,交互的应用。

    2015年3月26日 -  Javascript MVC 框架DerbyJS DerbyJS 是一个 MVC 框架,帮助编写实时,交互的应用.

  9. mysql--->profile使用

    Mysql分析-profile详解 简介 Profiling是从 mysql5.0.3版本以后才开放的. 启动profile之后,所有查询包括错误的语句都会记录在内. 此工具可用来查询SQL执行状态, ...

  10. X-CTF(REVERSE高级) Reversing-x64Elf-100

    逻辑很简单,如果sub_4006FD函数返回假则返回Nice! 图1 进入sub_4006FD函数,加密过程也很简单,这里值得注意的有两点 一.8*(i%3)是二维数组的第一个参数,这里是取v3的地址 ...