A. Lesha and array splitting

水题模拟。(0:10)

题意:给你一个n个元素的数组,求能否把这个数组分成若干连续小段,使得每段的和不为0。如有多种解输出任意一个。

思路:搞一个前缀和,如果这个数列的和不为0那么就直接输出一个区间左为1右为n。如果数列和为0那么找一个点前面的和不为0且后面的和也不为0,直接输出这两个区间。

int a[N],sum[N];
int main()
{
int n;
while(~scanf("%d",&n))
{
memset(sum,0,sizeof(sum));
for(int i=1;i<=n;i++)
{
scanf("%d",&a[i]);
sum[i]=sum[i-1]+a[i];
}
if(sum[n])
{
printf("YES\n");
printf("1\n1 %d\n",n);
}
else
{
int x=0;
for(int i=1;i<n;i++)
{
if(sum[i]&&(sum[n]-sum[i])!=0)
{
x=i;
break;
}
}
if(x)
{
printf("YES\n");
if(x!=n) printf("2\n");
else printf("1\n");
printf("1 %d\n",x);
if(x<n) printf("%d %d\n",x+1,n);
}
else printf("NO\n");
}
}
return 0;
}

B. Ilya and tic-tac-toe game

暴力或者搜索都行。(0:45)

题意:在4*4的棋盘上下三子棋, 只要有三个连续的就算赢。现在轮到Ilya下子了,Ilya的棋子是x。问只下一步是否能赢。

思路:所有的情况貌似也不多,全部特判就行,不过要蛮细心的。

string str[5];
int judge(int i,int j)
{
if((i-1)>=0&&str[i-1][j]=='x'&&(i-2)>=0&&str[i-2][j]=='x') return 1;
if((i-1)>=0&&str[i-1][j]=='x'&&(i+1)<4&&str[i+1][j]=='x') return 1;
if((i+1)<4&&str[i+1][j]=='x'&&(i+2)<4&&str[i+2][j]=='x') return 1;
// printf("1\n"); if((j-1)>=0&&str[i][j-1]=='x'&&(j+1)<4&&str[i][j+1]=='x') return 1;
if((j-1)>=0&&str[i][j-1]=='x'&&(j-2)>=0&&str[i][j-2]=='x') return 1;
if((j+1)<4&&str[i][j+1]=='x'&&(j+2)<4&&str[i][j+2]=='x') return 1;
//printf("2\n"); if(i+1<4&&i-1>=0&&j-1>=0&&j+1<4&&str[i-1][j-1]==str[i+1][j+1]&&str[i-1][j-1]=='x') return 1;
if(i+1<4&&i-1>=0&&j-1>=0&&j+1<4&&str[i+1][j-1]==str[i-1][j+1]&&str[i+1][j-1]=='x') return 1;
//printf("3\n"); if(i-2>=0)
{
if(j-2>=0)
{
if(str[i-1][j-1]=='x'&&str[i-2][j-2]=='x') return 1;
}
if(j+2<4)
{
if(str[i-1][j+1]=='x'&&str[i-2][j+2]=='x') return 1;
}
}
if(i+2<4)
{
if(j+2<4)
{
if(str[i+1][j+1]=='x'&&str[i+2][j+2]=='x') return 1;
}
if(j-2>=0)
{
if(str[i+1][j-1]=='x'&&str[i+2][j-2]=='x') return 1;
}
}
// printf("4\n");
return 0;
}
void fun()
{
int f=1;
for(int i=0;i<4&&f;i++)
for(int j=0;j<4&&f;j++)
if(str[i][j]=='.'&&judge(i,j)) f=0;
if(!f) printf("YES\n");
else printf("NO\n"); }
int main()
{
for(int i=0;i<4;i++)
cin>>str[i];
fun();
return 0;
}

D. Fedor and coupons

唉,好气啊,一个半小时A不出这道题。

题意:有n种优惠券,每种有一个优惠区间,也即是说编号在l到r的商品可以受到优惠。现在要你挑出k种优惠券,使得都能用这k种优惠券的商品数量越多越好。商品都是独一无二的。

思路:就是k个区间求交集最大范围。所有区间按左端点从小到大排序,然后用优先队列维护右端点最小值。满足k个区间并且两端点差值最大即可。

被尺取法误导了一下,以为用RMQ求【i,i+k】区间的右端点最小值然后得出差值最大,一直WA在第5组。比完赛才知道用优先队列维护。

struct node
{
ll l,r;
int i;
} a[N];
int n,k;
int cmp(node a,node b)
{
return a.l<b.l;
}
int main()
{
while(~scanf("%d%d",&n,&k))
{
for(int i=1; i<=n; i++)
{
scanf("%I64d%I64d",&a[i].l,&a[i].r);
a[i].i=i;
}
sort(a+1,a+n+1,cmp);
ll ma=0,r=0,l=0;
priority_queue<ll,vector<ll>,greater<ll> >que;//最小值优先;
for(int i=1; i<=n; i++)
{
que.push(a[i].r);
int siz=(int)que.size();
if(siz>k) que.pop();
ll len=que.top()-a[i].l+1;
// printf("%I64d %I64d %I64d\n",a[i].l,que.top(),len);
if(siz>=k&&len>ma)
{
l=a[i].l;
r=que.top();
ma=len;
}
}
printf("%I64d\n",ma);
if(ma)
{
for(int i=1; i<=n&&k; i++)
{
if(a[i].l<=l&&a[i].r>=r)
{
printf("%d ",a[i].i);
k--;
}
}
}
else
{
for(int i=1; i<=k; i++)
printf("%d ",i);
}
printf("\n");
}
return 0;
}

Codeforces Round #390 (Div. 2) A+B+D!的更多相关文章

  1. Codeforces Round #390 (Div. 2) D. Fedor and coupons(区间最大交集+优先队列)

    http://codeforces.com/contest/754/problem/D 题意: 给定几组区间,找k组区间,使得它们的公共交集最大. 思路: 在k组区间中,它们的公共交集=k组区间中右端 ...

  2. Codeforces Round #390 (Div. 2) C. Vladik and chat(dp)

    http://codeforces.com/contest/754/problem/C C. Vladik and chat time limit per test 2 seconds memory ...

  3. Codeforces Round #390 (Div. 2) A. Lesha and array splitting

    http://codeforces.com/contest/754/problem/A 题意: 给出一串序列,现在要把这串序列分成多个序列,使得每一个序列的sum都不为0. 思路: 先统计一下不为0的 ...

  4. Codeforces Round #390 (Div. 2)

    时隔一个月重返coding…… 期末复习了一个月也不亏 倒是都过了…… 就是计组61有点亏 复变68也太低了 其他都还好…… 假期做的第一场cf 三道题 还可以…… 最后room第三 standing ...

  5. Codeforces Round #390 (Div. 2) E(bitset优化)

    题意就是一个给出2个字符矩阵,然后进行匹配,输出每个位置的匹配的结果 (超出的部分循环处理) 一种做法是使用fft,比较难写,所以没有写 这里使用一个暴力的做法,考虑到一共只出现26个字符 所以使用一 ...

  6. Codeforces Round #390 (Div. 2) A B C D

    这是一场比较难的div2 ... 比赛的时候只出了AB A很有意思 给出n个数 要求随意的把相邻的数合并成任意多数 最后没有为0的数 输出合并区间个数与区间 可以想到0可以合到任何数上并不改变该数的性 ...

  7. Codeforces Round #390 (Div. 2) D

    All our characters have hobbies. The same is true for Fedor. He enjoys shopping in the neighboring s ...

  8. Codeforces Round #390 (Div. 2) B

    Ilya is an experienced player in tic-tac-toe on the 4 × 4 field. He always starts and plays with Xs. ...

  9. Codeforces Round #390 (Div. 2) A

    One spring day on his way to university Lesha found an array A. Lesha likes to split arrays into sev ...

随机推荐

  1. 在webconfig放置固定值

    通常的,为了布置到服务器后修改的方便通常把一些会改变的值放在webconfig: 首先在web.ocnfig中放入如下值 <appSettings> <add key="A ...

  2. python第一模块数据类型

    一·进制之间的转换 十进制转换为二进制:逆序取余法. 二进制转换为十进制:如1101  1*2^0 + 0*2^1 + 1*2^2 +1 十六进制转换为二进制:231     0010  0011   ...

  3. Number of 1 BitsWrite a function that takes an unsigned integer and returns the number of ’1' bits i

    Write a function that takes an unsigned integer and returns the number of ’1' bits it has (also know ...

  4. 利用UnblockNeteaseMusic实现网易云破版权,并实现shell可快速访问

    注:本篇包含mac及windows下安装方式详细 mac安装 前提:安装有node环境,可参考 mac下安装nodejs 安装 下载git代码到本地 git clone https://github. ...

  5. activeandroid复制本地数据库问题总结

    activeandroid no such table 解决activeandroid no such table failed to read row 0 column 1 from a curso ...

  6. java.sql.SQLException: Incorrect string value: '\xE6\x88\x91\xE7\x9A\x84...' for column 'groupName'

    java.sql.SQLException: Incorrect string value: '\xE6\x88\x91\xE7\x9A\x84...' for column 'groupName' ...

  7. (七)VMware Harbor 问题:Get https://192.168.3.135:8088/v2/: http:server gave HTTP response to HTTPS client

    (一)问题描述 登陆时,报错 docker Get https://192.168.3.135:8088/v2/: http:server gave HTTP response to HTTPS cl ...

  8. CAD交互绘制mcdbsolid对象(网页版)

    主要用到函数说明: _DMxDrawX::DrawSolid 绘McDbSolid对象.详细说明如下: 参数 说明 DOUBLE dX1 第一个点X DOUBLE dY1 第一个点Y DOUBLE d ...

  9. 对Java提供的锁机制的一些思考

    Java的数据会在CPU.Register.Cache.Heap和Thread stack之间进行复制操作,而前面四个都是在Java Threads之间共享,因此Java的锁机制主要用于解决Racin ...

  10. 【技巧:字符串同构】Avendesora

    判断字符串“同构”的技巧 题目大意 给定A,B两个序列,要求B在A中出现的次数以及位置.定义字符变换:把所有相同的字符变为另一种字符:两个字符串相等:当且仅当一个字符串可以在若干次字符变换之后变为另一 ...