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. cnblog之初来乍到

    hello,大家好,我是蓝斯老师 一枚致力于android开发的攻城狮 很荣幸能够在博客园开博(博主以前是混CSDN的,原博客地址http://blog.csdn.net/lancees) 希望将来能 ...

  2. C++拾遗(二)——初窥标准库类型

    本篇博文的开始,先介绍一道书上看到的智力题:有20瓶药丸,其中19瓶装有1克/粒的药丸,余下一瓶装有1.1克/粒的药丸.有一台称重精准的天平,只是用一次天平的情况下如何找出比较重的那瓶药丸? 好了,直 ...

  3. 洛谷 P1168 中位数

    题目描述 给出一个长度为N的非负整数序列A[i],对于所有1 ≤ k ≤ (N + 1) / 2,输出A[1], A[3], …, A[2k - 1]的中位数.[color=red]即[/color] ...

  4. cannot load such file -- bundler/setup解决

    sudo gem install bundler bundle update celluloid

  5. osx launchpad图标的删除

    安装了个parallels desktop之后,OSX中的launchpad中的图标多了不少,可是好多都不是我自己想要的,我们该怎么删除或者修改呢,下面介绍一些方法: ①直接操作Appications ...

  6. Python基础篇 -- 字符串

    字符串 字符串是不可变的对象,任何操作对原字符串是不会有任何影响的. 索引和切片 索引 . 索引就是下标, 下标从 0 开始, 使用[] 来获取数据 s1 = "0123456" ...

  7. POI读word doc 03 文件的两种方法

    Apache poi的hwpf模块是专门用来对word doc文件进行读写操作的.在hwpf里面我们使用HWPFDocument来表示一个word doc文档.在HWPFDocument里面有这么几个 ...

  8. HTML5拖放(drag和drog)

    拖放(drag和drog)是HTML5的标准的组成部分,也是种常见的特性,意义为抓起一个元素放入到另外的一个位置,在HTML5中任何元素都可以被拖放,前题是要相关进行设置. 1.设置元素为可拖放,也就 ...

  9. XML解析(一) DOM解析

    XML解析技术主要有三种: (1)DOM(Document Object Model)文档对象模型:是 W3C 组织推荐的解析XML 的一种方式,即官方的XML解析技术. (2)SAX(Simple ...

  10. Log4J的配置与使用详解

    一.简介 Log4j是Apache的一个开放源代码项目,通过使用Log4j,我们可以控制日志信息输送的目的地是控制台.文件.GUI组件.甚至是套接口服务器.NT的事件记录器.UNIX Syslog守护 ...