奶昔队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】的更多相关文章

  1. #6164. 「美团 CodeM 初赛 Round A」数列互质-莫队

    #6164. 「美团 CodeM 初赛 Round A」数列互质 思路 : 对这个题来言,莫队可以 n*根号n 离线处理出各个数出现个的次数 ,同时可以得到每个次数出现的次数 , 但是还要处理有多少 ...

  2. 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 ...

  3. 队爷的讲学计划 CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的讲学计划 题解:刚开始理解题意理解了好半天,然后发 ...

  4. 队爷的Au Plan CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的Au%20Plan 题解:看了题之后觉得肯定是DP ...

  5. 队爷的新书 CH Round #59 - OrzCC杯NOIP模拟赛day1

    题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的新书 题解:看到这题就想到了 poetize 的封 ...

  6. Yandex.Algorithm 2011 Round 2 D. Powerful array 莫队

    题目链接:点击传送 D. Powerful array time limit per test 5 seconds memory limit per test 256 megabytes input ...

  7. 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 ...

  8. 莫队 Codeforces Round #340 (Div. 2) E

    题目大意:给你一个长度为n的序列,有m个询问,每次询问一个区间[L,R],表示这个区间内,有多少的a[i]^a[i+1].....^a[j]=k. 思路:莫队去搞就好了 我们定义pre[i]=a[1] ...

  9. 「知识学习&日常训练」莫队算法(一)(Codeforce Round #340 Div.2 E)

    题意 (CodeForces 617E) 已知一个长度为\(n\)的整数数列\(a[1],a[2],-,a[n]\),给定查询参数\(l,r\),问\([l,r]\)内,有多少连续子段满足异或和等于\ ...

随机推荐

  1. poj1573 Robot Motion

    Robot Motion Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 12507   Accepted: 6070 Des ...

  2. SQLite 增、删、改、查

    1.iOS中实现SQLite的增.删.改.查  http://www.jianshu.com/p/0b9b78e704a4. 2.用数据库实现收藏功能 http://www.jianshu.com/p ...

  3. slice,substr和substring的区别

    首先,他们都接收两个参数,slice和substring接收的是起始位置和结束位置(不包括结束位置),而substr接收的则是起始位置和所要返回的字符串长度.直接看下面例子: var test = ' ...

  4. django复习笔记1:环境配置

    一.IDE 推荐使用sublime安装djaneiro插件. 1.安装方式 package control中搜索djaneiro 支持补全请参考:Django support for Sublime ...

  5. python读取配置文件

    从/mnt目录下读取section配置文件sample.ini [db] host=192.168.1.116 hostaddr=192.168.1.116 port=5432 dbname=clas ...

  6. c语言 指针与数组

    关键概念: 1.多个不同类型的指针可以对应同一个地址: 2.(&p)则是这样一种运算,返回一个指针,该指针的值是当时声明p 时开辟的地址,指针的类型是p的类型对应的指针类型: 3.(*p)操作 ...

  7. linux中vi编辑器的使用

    vi编辑器是所有Unix及Linux系统下标准的编辑器,它的强大不逊色于任何最新的文本 编辑器,这里只是简单地介绍一下它的用法和一小部分指令.由于对Unix及Linux系统的任 何版本,vi编辑器是完 ...

  8. 纯手工打造漂亮的瀑布流,五大插件一个都不少Bootstrap+jQuery+Masonry+imagesLoaded+Lightbox!

    前两天写的文章<纯手工打造漂亮的垂直时间轴,使用最简单的HTML+CSS+JQUERY完成100个版本更新记录的华丽转身!>受到很多网友的喜爱,今天特别推出姊妹篇<纯手工打造漂亮的瀑 ...

  9. 由一次程序崩溃引起的对new表达式的再次学习

    1. 起因 某天,一个同事跟我反馈说在windows上调试公司产品的一个交易核心时出现了使用未初始化的指针导致后台服务崩溃的情况.示例代码如下所示: struct sample { ][]; //.. ...

  10. closure!

    总结一下闭包. 闭包的定义:当一个内部函数被其外部函数之外的变量所引用时,就形成了一个闭包. 一个最简单的闭包: function A(){ var count=0; return function( ...