CodeForces 680A&680B&680C&680D Round#356
昨天晚上实在是=_=困。。。(浪了一天)就没有去打Codeforces
中午醒来看看题,还不太难。
A题:模拟(水题 3minAC)
// by Sirius_Ren
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
int a[6],sum=0,ans;
bool cmp(int a,int b){return a>b;}
int main()
{
for(int i=1;i<=5;i++)scanf("%d",&a[i]),sum+=a[i];
ans=sum;
sort(a+1,a+6,cmp);
for(int i=1;i<=5;i++)
for(int j=1;j<=2;j++){
if(a[i]!=a[i+j])break;
ans=min(ans,sum-a[i]-a[i]);
if(j==2)ans=min(ans,sum-a[i]-a[i]-a[i]);
}
printf("%d",ans);
}
B:(水题 5minAC)
// by Sirius_Ren
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
int n,a,ans=0;
bool v[105];
int main(){
scanf("%d%d",&n,&a);
for(int i=1;i<=n;i++)scanf("%d",&v[i]);
for(int i=0;i<=n;i++){
if(a-i>0&&a+i<=n&&v[a-i]&&v[a+i]&&i)ans+=2;
else if(a-i>0&&a+i<=n&&v[a-i]&&v[a+i]&&!i)ans++;
else if(a-i<=0&&a+i<=n&&v[a+i])ans++;
else if(a-i>0&&a+i>n&&v[a-i])ans++;
}
printf("%d",ans);
}
C:一道数学题。
枚举50以内的素数,最后判断有没有i*i(i^2<50)的即可。
一个yes—>素数
否则—->合数
// by Sirius_Ren
#include <cstdio>
#include <iostream>
using namespace std;
int a[20]={2,3,5,7,11,13,17,19,23,29,31,37,41,43,47,4,8,9,25,49},ans=0;
char s[20][5];
int main()
{
for(int i=0;i<20;i++){printf("%d\n",a[i]);fflush(stdout);scanf("%s",s[i]);}
for(int i=0;i<20;i++)if(s[i][0]=='y')ans++;
if(ans>=2)printf("composite\n");
else printf("prime\n");
}
(呃其实没有“8”,当时多打了一个,不过也没关系,AC就是王道)
D:
http://www.cnblogs.com/macinchang/p/5572070.html
照着他的题解写得。 没有什么思路。。。。
// by Sirius_Ren
#include <cstdio>
#include <algorithm>
using namespace std;
long long a;
long long p(long long x){return x*x*x;}
pair<int,long long>b;
void w(long long x,int y,long long z){
if(!x){b=max(b,make_pair(y,z));return;}
long long t=1;
while(p(t+1)<=x)++t;
w(x-p(t),y+1,z+p(t));
if(x)w(p(t)-1-p(t-1),y+1,z+p(t-1));
}
int main(){
scanf("%I64d",&a),w(a,0,0);
printf("%d %I64d",b.first,b.second);
}
E:第10个点WA了,并不知道怎么改。 大数据挂了。。。
// by Sirius_Ren
#include <set>
#include <queue>
#include <cstdio>
#include <algorithm>
#define ff(aa,bb,cc,dd) for(int i=aa;i<=bb;i++)for(int j=cc;j<=dd;j++)
#define f(aa,bb) for(int i=aa;i<=bb;i++)
using namespace std;
set<int>s;
queue<int>que;
set<int>::iterator it;
int n,k,tot=0,jy,vis[501][501],v[500000],q[500000],ans=0,Q=0;
char xx[]={1,-1,0,0},yy[]={0,0,1,-1},a[501][501];
void Dfs(int x,int y){
jy++,vis[x][y]=tot;
f(0,3)if(!vis[x+xx[i]][y+yy[i]]&&a[x+xx[i]][y+yy[i]]=='.')Dfs(x+xx[i],y+yy[i]);
}
void dfs(int x,int y)
{
while(!que.empty())s.erase(que.front()),que.pop();
for(int i=0;i<k;i++)
if(vis[x+i][y-1])
{
q[vis[x+i][y-1]]--;
if(!q[vis[x+i][y-1]])s.erase(vis[x+i][y-1]);
}
else if(a[x+i][y-1]=='X')jy--;
for(int i=0;i<k;i++)
if(vis[x+i][y+k-1])
{
if(!q[vis[x+i][y+k-1]])s.insert(vis[x+i][y+k-1]);
q[vis[x+i][y+k-1]]++;
}
else if(a[x+i][y+k-1]=='X')jy++;
for(int i=0;i<k;i++)if(vis[x-1][y+i]&&s.find(vis[x-1][y+i])==s.end())s.insert(vis[x-1][y+i]),que.push(vis[x-1][y+i]);
for(int i=0;i<k;i++)if(vis[x+k][y+i]&&s.find(vis[x+k][y+i])==s.end())s.insert(vis[x+k][y+i]),que.push(vis[x+k][y+i]);
for(int i=0;i<k;i++)if(vis[x+i][y-1]&&s.find(vis[x+i][y-1])==s.end())s.insert(vis[x+i][y-1]),que.push(vis[x+i][y-1]);
for(int i=0;i<k;i++)if(vis[x+i][y+k]&&s.find(vis[x+i][y+k])==s.end())s.insert(vis[x+i][y+k]),que.push(vis[x+i][y+k]);
int temp=jy;
for(it=s.begin();it!=s.end();it++)temp+=v[*it];
ans=max(ans,temp);
if(y+k<=n)dfs(x,y+1);
for(int i=0;i<k;i++)
if(vis[x+i][y-1])
{
if(!q[vis[x][i-1]])s.insert(vis[x][i-1]);
q[vis[x][i-1]]++;
}
else if(a[x+i][y-1]=='X')jy++;
for(int i=0;i<k;i++)
if(vis[x+i][y+k-1])
{
q[vis[x+i][y+k-1]]--;
if(!q[vis[x+i][y+k-1]])s.erase(vis[x+i][y+k-1]);
}
else if(a[x+i][y+k-1]=='X')jy--;
if(x+k<=n&&y==1)
{
for(int i=1;i<k;i++)
{
if(vis[x][i])
{
q[vis[x][i]]--;
if(!q[vis[x][i]])s.erase(vis[x][i]);
}
else if(a[x][i]=='X')jy--;
}
for(int i=1;i<k;i++)
{
if(vis[x+k][i])
{
q[vis[x+k][i]]++;
}
else if(a[x+k][i]=='X')jy++;
}
dfs(x+1,1);
}
}
int main(){
scanf("%d%d",&n,&k);
ff(1,n,0,n)scanf("%c",&a[i][j]);
ff(1,n,1,n)if(!vis[i][j]&&a[i][j]=='.')jy=0,tot++,Dfs(i,j),v[tot]=jy;
jy=0;
ff(1,k,1,k-1)
if(a[i][j]=='X')jy++;
else{
if(!q[vis[i][j]])s.insert(vis[i][j]);
q[vis[i][j]]++;
}
dfs(1,1);
printf("%d",ans);
}
E题已挂。
CodeForces 680A&680B&680C&680D Round#356的更多相关文章
- Codeforces Round #356 (Div. 2)-B
B. Bear and Finding Criminals 链接:http://codeforces.com/contest/680/problem/B There are n cities in B ...
- Codeforces Round #356 (Div. 2)-A
A. Bear and Five Cards 题目链接:http://codeforces.com/contest/680/problem/A A little bear Limak plays a ...
- Codeforces Round #356 (Div. 2) C. Bear and Prime 100(转)
C. Bear and Prime 100 time limit per test 1 second memory limit per test 256 megabytes input standar ...
- Codeforces Round #356 (Div. 2)B. Bear and Finding Criminals(水题)
B. Bear and Finding Criminals time limit per test 2 seconds memory limit per test 256 megabytes inpu ...
- Codeforces Round #356 (Div. 2)A. Bear and Five Cards(简单模拟)
A. Bear and Five Cards time limit per test 2 seconds memory limit per test 256 megabytes input stand ...
- 并查集+bfs+暴力滑窗 Codeforces Round #356 (Div. 2) E
http://codeforces.com/contest/680/problem/E 题目大意:给你一个n*n的图,然后图上的 . (我们下面都叫做‘点’)表示可以走,X表示不能走,你有如下的操作, ...
- dfs Codeforces Round #356 (Div. 2) D
http://codeforces.com/contest/680/problem/D 题目大意:给你一个大小为X的空间(X<=m),在该空间内,我们要尽量的放一个体积为a*a*a的立方体,且每 ...
- Codeforces Round #356 (Div. 1) D. Bear and Chase 暴力
D. Bear and Chase 题目连接: http://codeforces.com/contest/679/problem/D Description Bearland has n citie ...
- Codeforces Round #356 (Div. 2) E. Bear and Square Grid 滑块
E. Bear and Square Grid 题目连接: http://www.codeforces.com/contest/680/problem/E Description You have a ...
随机推荐
- CAD把一个DWG文件中的多个图框一次性全部插入到打开的DWG文件中
主要用到函数说明: _DMxDrawX::InsertBlock 向控件数据库中插入一个图块,不用它插入匿名块,详细说明如下: 参数 说明 BSTR pszDwgFileName 图块定义的dwg 文 ...
- zabbix--TCP状态监控
Tcp的连接状态对于我们web服务器来说是至关重要的,尤其是并发量ESTAB:或者是syn_recv值,假如这个值比较大的话我们可以认为是不是受到了攻击(例如SYN攻击),或是是time_wait值比 ...
- 无需编写代码,用接口管理工具 eoLinker 高效完成API测试流程相关业务
引言 作为开发人员,有时需要协助市场部门进行开发,比如在市场推广中,经常通过给用户赠送优惠券来提高复购率.这篇文章,将介绍如何使用接口管理工具 eoLinker 的自动化测试 [UI模式] 构建此业务 ...
- JavaScript day3(转义符)
转义符(escape character) 当你定义一个字符串必须要用单引号或双引号来包裹它.那么当你需要在字符串中使用一个: " 或者 ' 时该怎么办呢? 在 JavaScript 中可 ...
- Linux之iptables(二、基本认识和组成)
iptables的基本认识 Netfilter组件 内核空间,集成在linux内核中 扩展各种网络服务的结构化底层框架 内核中选取五个位置放了五个hook(勾子) function(INPUT.OUT ...
- codeforeces近日题目小结
题目源自codeforeces的三场contest contest/1043+1055+1076 目前都是solved 6/7,都差了最后一题 简单题: contest/1043/E: 先不考虑m个限 ...
- Windows读取NXP MiFare Ultralight C类型NFC卡片的信息
1,读取 我们需要外接一个NFC Reader让Windows可以读取NFC卡片的内容. 因为特殊原因,我们选择了Sony rc-s380 NFC Reader.相关介绍 我们需要下载并安装NFC P ...
- 清北学堂模拟赛d1t6 或和异或(xor)
题目描述 LYK最近在研究位运算,它研究的主要有两个:or和xor.(C语言中对于|和^) 为了更好的了解这两个运算符,LYK找来了一个2^n长度的数组.它第一次先对所有相邻两个数执行or操作,得到一 ...
- [USACO16OPEN]关闭农场Closing the Farm(洛谷 3144)
题目描述 Farmer John and his cows are planning to leave town for a long vacation, and so FJ wants to tem ...
- Python图像处理库PIL中图像格式转换(一)
在数字图像处理中,针对不同的图像格式有其特定的处理算法. 所以,在做图像处理之前,我们须要考虑清楚自己要基于哪种格式的图像进行算法设计及事实上现.本文基于这个需求.使用python中的图像处理库PIL ...