【奶昔队ROUND#1】
奶昔队Round #1 热身
(奶昔队不是真正的队,是群)
CodeForces 435C Cardiogram
模拟,不过我做的时候不是模拟,是计算...(写了好久,还wa了几次),现在看了别人的代码写过一份。
#include <iostream>
#include <algorithm>
#define N 1005
using namespace std;
int n,x,y,a,h,l;
char ma[N<<][N];
int main() {
cin>>n;
h=l=y=;
for(int i=;i<=n;i++){
cin>>a;
while(a--) if(i&) ma[++y][++x]='/';
else ma[--y][++x]='\\';
h=max(h,y);
l=min(l,y);
y+=i%?:-;
}
for(int i=h;i>=l;i--){
for(int j=;j<=x;j++)
if(ma[i][j])cout<<ma[i][j];
else cout<<" ";
cout<<endl;
}
}
CodeForces 437B The Child and Set
sum=Σlowbit(x),x不超过limit。
贪心,把1到limit的所有lowbit求出来,按lowbit值从大到小排个序,每次取完一个就把sum减去一个数。
#include <iostream>
#include <algorithm>
#define lowbit(x) ((x)&-(x))
using namespace std;
int sum,limit,ans;
struct num{
int id,low,ok;
}a[];
int cmp(num a,num b){
return a.low>b.low;
}
int main() {
cin>>sum>>limit;
for(int i=;i<=limit;i++){
a[i].id=i;
a[i].low=lowbit(i);
}
sort(a+,a+limit+,cmp);
for(int i=;i<=limit&∑i++)
if(a[i].low<=sum){
a[i].ok=;
ans++;
sum-=a[i].low;
}
if(sum==){
cout<<ans<<endl;
for(int i=;i<=limit;i++)if(a[i].ok)
cout<<a[i].id<<" ";
}else
cout<<"-1";
}
CodeForces 437C C - The Child and Toy
删除每个点,就需要它相邻的点(未删除的)权值和的代价,求全部点删完后的最小代价。
贪心,一定是删权值最大的点,那么删掉时,对于相邻的边,就是花费了较小的相邻点的权值,于是直接对每条边取小的点加起来。
#include <iostream>
#include <algorithm>
#define N 1005
using namespace std;
int n,m,ans,v[N],a,b;
int main() {
cin>>n>>m;
for(int i=;i<=n;i++)
cin>>v[i];
for(int i=;i<=m;i++){
cin>>a>>b;
ans+=min(v[a],v[b]);
}
cout<<ans; }
奶昔队Round #1
CodeForces 527A A. Playing with Paper
问一张纸能分多少个尽量大的正方形
#include <iostream>
using namespace std;
long long a,b,ans;
int main(){
cin>>a>>b;
while(a%b){
ans+=a/b;
a%=b;
swap(a,b);
}
cout<<ans+a/b;
}
CodeForces 526A B. King of Thieves
就是找5个相距固定的*,居然把字符串从1开始,智障了。
#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
int ok(char c){
return c=='*';
}
char s[];
int main() {
int n;
cin>>n;
cin>>s;
for(int l=;l<=n;l++){
for(int j=;j<n;j++){
int ans=ok(s[j]);
for(int a=;a<=;a++)
if(!ok(s[j+l*a]))ans=;
if(ans){
puts("yes");
return ;
}
}
}
puts("no");
return ;
}
CodeForces 526B C. Om Nom and Dark Park
从叶子节点往根的方向,每两个兄弟的差值加到答案上,父节点的值加上较大的那个儿子的值。
#include <iostream>
using namespace std;
int n,a[<<],ans;
int main() {
cin>>n;
for(int i=;i<(<<(n+));i++)
cin>>a[i];
for(int k=n;k;k--)
for(int i=(<<k);i<(<<(k+));i+=){
a[i>>]+=max(a[i],a[i+]);
ans+=max(a[i],a[i+])-min(a[i],a[i+]);
}
cout<<ans<<endl;
}
CodeForces 526C D. Om Nom and Candies
红糖果和蓝糖果均有开心值和重量,要总质量不超过c,开心值最大有多少。
- 如果b更划得来,那么吃相同重量时,会选择b,于是r的数量就会小于wb;反之,则b的数量会小于wr。
- wr*i+wb*j≤c,如果wr>√c,那么i<√c,如果wb>√c,那么j<√c,直接枚举就行了,否则,wb和wr就都小于√c。
#include <iostream>
#define ll long long
using namespace std;
ll c,hr,hb,wr,wb,ans;
int main() {
cin>>c>>hr>>hb>>wr>>wb;
if(wr>=c/wr||hr*wb<wr*hb&&wb<c/wb)
{
swap(wb,wr);
swap(hb,hr);
}
for(int i=;i*i<=c&&i<=c/wb;i++)
ans=max(ans,(c-i*wb)/wr*hr+i*hb);
cout<<ans;
}
CodeForces 526D E. Om Nom and Necklace
对于n(<=100万)位的字符串,问你每个前缀是否可以划分为ABAB..ABA的形式,其中A、B代表字符串(A或B可以为空),且B出现m次。
这种题目很不好想,对于我来说。
当前前缀P=SSSSS...SST=m个AB+1个A,AB一定是几个S组成,A为P的后缀
共有R个S,分到m组里,余下的则是A的前缀。
A里面有R%m个S
B里面有R/m-R%m个S
KMP算出循环节长度len=i-Next[i],则
循环次数R=i/len
如果i%len==0,代表全为S,算出来如果B为空也是可以的,
否则,B为空不可以。
#include <cstdio>
#define N 1000005
using namespace std; char s[N];
int n,m,Next[N],ans[N];
int main() {
scanf("%d%d%s",&n,&m,s);
int k=-,i=;
Next[i]=k;
while(s[i])
if(k==-||s[i]==s[k]){
Next[++i]=++k;
int len=i-Next[i],R=i/len;
if(i%len==)
ans[i]=(R/m-R%m>=);
else
ans[i]=(R/m-R%m>);
}else k=Next[k];
for(int i=;i<=n;i++)
printf("%d",ans[i]);
puts("");
}
CodeForces 526E F. Transmitting Levels
对于100万个数围成的环,求最少能切几段,每段的和不超过b,有q次询问。
滑窗,from[i]表示from[i]到i是已经划分了的段,ans[i]表示from[i]到i的最少段数。
左端为j,右端为i。
一开始j到i为一段,如果超过b,j右移,这样就求出i为右端的最大的一段,然后i右移,
from[i]=from[j],ans[i]=ans[j]+1;相当于j结尾后面又划分了一段。
继续求直到i-from[i]≥n。
#include<cstdio>
#include<cstdlib>
#include<algorithm>
#include<cmath>
#include<cstring> typedef long long ll; using namespace std;
const int MAXN = +; int a[MAXN*];
int from[MAXN * ], ans[MAXN * ];
ll ss[MAXN*]; int main(){
int n, q;
scanf("%d%d", &n, &q);
for(int i=;i<=n;i++){
scanf("%d", &a[i]);
a[i+n] = a[i];
from[i]=i;
ans[i]=;
}
for(int i=;i<=*n;i++) ss[i]=ss[i-]+a[i]; for(int Q=;Q<=q;Q++){
int lim;
scanf("%d", &lim);
memset(ans, , sizeof(ans));
//memset(from, 0, sizeof(from));
int j = ;
for(int i=n+;i<=*n;i++){
while(ss[i]-ss[j]>lim) j++;
ans[i] = ans[j]+;
from[i] = from[j];
if(i-from[i]>=n){
printf("%d\n", ans[i]);
break;
}
}
//printf("%d\n", ans[2*n]);
} }
【奶昔队ROUND#1】的更多相关文章
- #6164. 「美团 CodeM 初赛 Round A」数列互质-莫队
#6164. 「美团 CodeM 初赛 Round A」数列互质 思路 : 对这个题来言,莫队可以 n*根号n 离线处理出各个数出现个的次数 ,同时可以得到每个次数出现的次数 , 但是还要处理有多少 ...
- Codeforces Round #340 (Div. 2) E. XOR and Favorite Number 莫队算法
E. XOR and Favorite Number 题目连接: http://www.codeforces.com/contest/617/problem/E Descriptionww.co Bo ...
- 队爷的讲学计划 CH Round #59 - OrzCC杯NOIP模拟赛day1
题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的讲学计划 题解:刚开始理解题意理解了好半天,然后发 ...
- 队爷的Au Plan CH Round #59 - OrzCC杯NOIP模拟赛day1
题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的Au%20Plan 题解:看了题之后觉得肯定是DP ...
- 队爷的新书 CH Round #59 - OrzCC杯NOIP模拟赛day1
题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的新书 题解:看到这题就想到了 poetize 的封 ...
- Yandex.Algorithm 2011 Round 2 D. Powerful array 莫队
题目链接:点击传送 D. Powerful array time limit per test 5 seconds memory limit per test 256 megabytes input ...
- Codeforces Round #340 (Div. 2) E 莫队+前缀异或和
E. XOR and Favorite Number time limit per test 4 seconds memory limit per test 256 megabytes input s ...
- 莫队 Codeforces Round #340 (Div. 2) E
题目大意:给你一个长度为n的序列,有m个询问,每次询问一个区间[L,R],表示这个区间内,有多少的a[i]^a[i+1].....^a[j]=k. 思路:莫队去搞就好了 我们定义pre[i]=a[1] ...
- 「知识学习&日常训练」莫队算法(一)(Codeforce Round #340 Div.2 E)
题意 (CodeForces 617E) 已知一个长度为\(n\)的整数数列\(a[1],a[2],-,a[n]\),给定查询参数\(l,r\),问\([l,r]\)内,有多少连续子段满足异或和等于\ ...
随机推荐
- [No000051]如何去掉word复制过来的文字背景色?
我们经常从网上copy一些自己需要的材料到word里.不过常常会把别人的背景色一起拷贝过来.那么如何去掉word复制过来的文字背景色? 方法/步骤 第一步选ctrl+A(全选),找到页面布局→页面边框 ...
- ACCP7.0-S2-复习自测-15测试分析
3.下列关于java中集合接口的说法不正确的是(). A: B: C: D: 正确答案是 D 4. (选择一项) A: B: C: D: 正确答案是 D 5. (选择一项) A: B: C: D: ...
- ubuntu系统下的防火墙使用
apt-get install ufw 安装防火墙sudo ufw enable|disable|status 开启/关闭/查看防火墙状态sudo ufw allow 22/ ...
- Centos6.5 设置nfs
安装 rpcbind 和 nfs-utils yum install rpcbind yum install nfs-utils 设置共享目录 [root@bogon ~]# vim /etc/exp ...
- Linux shell文本过滤
正则表达式 --概念:一种用来描述文本模式的特殊语法 --由普通字符(例如:字符a到z),以及特殊字符(元字符,如/*?等)组成匹配的字符串 --文本过滤工具在某种模式之下,都支持正则表达式 --基本 ...
- Python之线程、进程和协程
python之线程.进程和协程 目录: 引言 一.线程 1.1 普通的多线程 1.2 自定义线程类 1.3 线程锁 1.3.1 未使用锁 1.3.2 普通锁Lock和RLock 1.3.3 信号量(S ...
- mac OS X Yosemite 上编译hadoop 2.6.0/2.7.0及TEZ 0.5.2/0.7.0 注意事项
1.jdk 1.7问题 hadoop 2.7.0必须要求jdk 1.7.0,而oracle官网已经声明,jdk 1.7 以后不准备再提供更新了,所以趁现在还能下载,赶紧去down一个mac版吧 htt ...
- JAVA CDI 学习(1) - @Inject基本用法
CDI(Contexts and Dependency Injection 上下文依赖注入),是JAVA官方提供的依赖注入实现,可用于Dynamic Web Module中,先给3篇老外的文章,写得很 ...
- TinyFrame升级之五:全局缓存的设计及实现
在任何框架中,缓存都是不可或缺的一部分,本框架亦然.在这个框架中,我们的缓存分为两部分:内存缓存和单次请求缓存.简单说来,就是一个使用微软提供的MemoryCache做扩展,并提供全局唯一实例:另一个 ...
- Webwork 学习之路【02】前端OGNL试练
1.OGNL 出现的意义 在mvc中,数据是在各个层次之间进行流转是一个不争的事实.而这种流转,也就会面临一些困境,这些困境,是由于数据在不同世界中的表现形式不同而造成的: a. 数据在页面上是一个扁 ...