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. netty-socketio即时通讯

    jar包和依赖包在360云盘中:所有文件 > 学习 > jar包 > netty-socketio-1.7.10以及依赖 原文链接:http://www.cnblogs.com/al ...

  2. jQuery事件,对象以及插件

    回顾 1 基本使用 2 jquery 选择器 3 筛选器 过滤 查找 串联 4 DOM 操作 内部插入 append()appendTo()prepend()prependTo() 外部插入 afte ...

  3. (转)Linux下清理Cache方法

    频繁的文件访问会导致系统的Cache使用量大增, 系统运行缓慢. 1 首先用free 命令查看内存的使用:$ free -m             total       used       fr ...

  4. 解决 FusionCharts3.2.1 首页无法载入的问题

    在实际项目中测试FusionCharts3.2.1时,发现首次载入无法正常载入,第二次载入就恢复正常!   原因:FusionCharts ID与变量名重复   以下是正常写法: var member ...

  5. Flask信号流程

    首先先我们来看看Flask里面的信号是什么样的,我们可以找到一个叫signals.py的文件 这里面是所有定义了的后面请求流程中会用到的信号 二.哪些地方用到了信号 1.请求app上下文时执行的,在执 ...

  6. SQLServer查询死锁

    --查询死锁 select request_session_id spid, OBJECT_NAME(resource_associated_entity_id) tableName from sys ...

  7. 图像处理框架 Core Image 介绍

    这篇文章会为初学者介绍一下 Core Image,一个 OS X 和 iOS 的图像处理框架. 如果你想跟着本文中的代码学习,你可以在 GitHub 上下载示例工程.示例工程是一个 iOS 应用程序, ...

  8. Error:(3, 32) java: 程序包org.springframework.boot不存在

     解决方案一: 找同事传一份D:\maven_repository\org\springframework\boot  ,如图所示的位置,添加进去立刻就不报红.我也可以给你发....  解决方案二: ...

  9. C# Process.Start方法

    System.Diagnostics.Process.Start(); 主要功能: 1.打开某个链接网址(弹窗). 2.定位打开某个文件目录. 3.打开系统特殊文件夹,如“控制面板”等. Proces ...

  10. python之list [ 列表 ]

    1. 列表是什么? list [ ] 逗号隔开 是一个容器 可以存放任意类型 列表 == 书包 书包里可以放水杯.衣服.袜子.钱包 钱包里可以放钱.身份证件,可以包套包 2. 列表能干什么? 存储大量 ...