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 ...
随机推荐
- GeckoWebBrowser设置cookie
var uri = new Uri("http://www.aa.com"); //often cookies are stored on domain level, so &qu ...
- select2下拉插件
下拉单选: 1.行内 1)初始化数据: <select class="form-control select5"> <option selected>张三1 ...
- CAD绘制一个对齐标注(com接口VB语言)
主要用到函数说明: _DMxDrawX::DrawDimAligned 绘制一个对齐标注.详细说明如下: 参数 说明 DOUBLE dExtLine1PointX 第一条界线开始点X值 DOUBLE ...
- python开发 面试题
一.简述列表与元组的区别 答: 元组tuple与列表List相同点 元组tuple与列表List都是序列类型的容器对象,可以存放任何类型的数据.支持切片.迭代等操作. 元组tuple与列表List区别 ...
- jquery 实现 单选框点击取消
<label for="1" class="z-label"> <input type="radio" class=&qu ...
- Windows下Unity安装
安装教程: https://www.paws3d.com/lesson/us-0101/ 问题1: 安装并完成注册后,在网页上能登录,但打开Unity时不能启动成功,一直停留在如下界面 解决方案:断网 ...
- Cashier (codeforces 1059A)
题目倒是不难注意第一个时间段可能不是从零开始的,所以注意第一个时间的开始节点与零之间可能存在休息的时间 还有这个题我打的时候一直谜之RE......发现原来bool函数忘记写return了.....以 ...
- Codeforces 919C - Seat Arrangements
传送门:http://codeforces.com/contest/919/problem/C 给出一张n×m的座位表(有已占座位和空座位),请选择同一行(或列)内连续的k个座位.求选择的方法数. H ...
- 实验十二 团队作业8:软件测试与Alpha冲刺 第五天
项目 内容 这个作业属于哪个课程 老师链接 这个作业的要求在哪里 实验十二 团队作业8:软件测试与Alpha冲刺 团队名称 Always Run! 作业学习目标 (1)掌握软件测试基础技术 (2)学习 ...
- Xen、OpenVZ、KVM、Hyper-V、VMWare虚拟化技术介绍
一.Xen 官网:http://xen.org/ Xen 由剑桥大学开发,它是基于硬件的完全分割,物理上有多少的资源就只能分配多少资源,因此很难超售.可分为Xen-PV(半虚拟化),和Xen-HVM( ...