今天又回到了C组,感觉爽歪歪~分数终于是个三位数了,yes!

第一题,赛车。水!只用一个贪心就可以AC了。

first,以速度为关键字小到大qsort一下。。。

scond,枚举每一个赛车,看看它可以去哪一个车道(取它开得最慢的那一个)。

then,输出答案。

finely,AC

第二题,数列。一眼望去,就是一道小学奥数题。

个位的1:N div 10+如果n mod 10 >0就是1,否则是0

十位的1:N div 10010+min(N%100,19)-9

百位的1:N div 1000
100+min(N%1000,199)-99

……

以此类推,我们可以得到一条公式(自己推)。

第三题,炸僵尸。宽搜。

PS:这些僵尸怎么那么眼熟?那个炸弹是小星星从椰子加农炮那里偷的吧!

言归正传。

我们先预处理一下,开四个数组:

left[i][j]:表示第i行第j列的点左边(包括它自己)的僵尸数量。

right[i][j]:表示第i行第j列的点右边(包括它自己)的僵尸数量。

up[i][j]:表示第i行第j列的点上面(包括它自己)的僵尸数量。

down[i][j]:表示第i行第j列的点下面(包括它自己)的僵尸数量。

注意墙!

然后对于一个没有僵尸的点,设它的坐标为(i,j),那么在它那里引爆就可以炸死left[i][j]+right[i][j]+up[i][j]+down[i][j]只僵尸。

然而比赛时80分,后来改到90分,最后的数据:

我输出26,正确答案24!

改了很久也没有对。

看标程时,发现标程的date数组(存走到过的点),只开到了10^5那么大,开小了!还没有走到可以炸26只僵尸的那个点就崩了(为什么不会运行时错误?!)。

于是告诉了老师这个问题,改了一下数据就AC了。

下面附上标程。

第四题,梦里的难题,很坑。

小星星真是的,胆子小还去看这种电影!

比赛时由于看了一下B组的题,还想了很久,时间不够用,就弃疗了。

只用把这串数字分成尽量多的几组,每一组都包含1~K的所有数,最后输出分的组数+1就可以了。

总结:不要浪费时间,下次继续努力!

第三题标程:

#include<cstdio>
using namespace std;
struct coordinate
{
int x,y;
}date[4000100];
char map[2010][2010];
int left[2010][2010],right[2010][2010],up[2010][2010],down[2010][2010];
bool b[2010][2010];
const int dx[4]={1,0,-1,0},
dy[4]={0,1,0,-1};
int main()
{
freopen("boom.in","r",stdin);
freopen("boom.out","w",stdout);
int n,m,tx,ty,i,j,head=0,tail=1,xx,yy,ans=0,k;
scanf("%d %d %d %d\n",&n,&m,&tx,&ty);
for(i=1;i<=n;i++)
{
for(j=1;j<=m;j++)
{
scanf("%c",&map[i][j]);
if(map[i][j]=='#') left[i][j]=up[i][j]=0;
else
{
left[i][j]=left[i][j-1];
up[i][j]=up[i-1][j];
if(map[i][j]=='G')
{
left[i][j]++;
up[i][j]++;
}
}
}
scanf("\n");
}
for(i=n;i>0;i--)
{
for(j=m;j>0;j--)
{
if(map[i][j]=='#') right[i][j]=down[i][j]=0;
else
{
right[i][j]=right[i][j+1];
down[i][j]=down[i+1][j];
if(map[i][j]=='G')
{
right[i][j]++;
down[i][j]++;
}
}
}
}
date[1].x=tx,date[1].y=ty;
b[tx][ty]=true;
while(head<tail)
{
head++;
xx=date[head].x,yy=date[head].y;
k=left[xx][yy]+right[xx][yy]+up[xx][yy]+down[xx][yy];
if(k>ans) ans=k;
for(i=0;i<4;i++)
{
xx=date[head].x+dx[i];
yy=date[head].y+dy[i];
if(map[xx][yy]=='.')
{
if(!b[xx][yy])
{
b[xx][yy]=true;
tail++;
date[tail].x=xx;
date[tail].y=yy;
}
}
}
}
printf("%d\n",ans);
return 0;
}

2017.9.23 C组比赛总结的更多相关文章

  1. 2017.10.28 C组比赛总结

    这次比赛有点坑... [GDKOI2004]石子游戏 方法:判断奇偶性 输入n 如果n是奇数,输出 xiaoshi 如果n是偶数,输出 xiaoyong 比赛得分:30 错因:找错规律了(忘记了两个人 ...

  2. 2017.10.21 C组比赛总结

    今天考得不太好,只拿了100+0+0+30=130分... [GDKOI训练]音乐节拍 考场AC了! 其实就是大水一道! 思路:二分查找 每次输入后,输出该时刻所在的区间的编号就好了. 总体难度:★★ ...

  3. IGF职业组比赛

    IGF职业组比赛 参赛资格: 面向亚太区所有独立游戏开发者(参见详细规则) 截止日期: 2015年7月20日 2015年IGF职业组七大奖项设置如下: * 最佳游戏(RMB20, 000) * 最佳移 ...

  4. 总结 Date 2017.09.23

    总结 Date 2017.09.23 <1>统计数字 某次科研调查时得到了n个自然数,每个数均不超过1500000000(1.5*10^9).已知不相同的数不超过10000个,现在需要统计 ...

  5. 2016.8.15上午纪中初中部NOIP普及组比赛

    2016.8.15上午纪中初中部NOIP普及组比赛 链接:https://jzoj.net/junior/#contest/home/1333 这次比赛不怎么好,因为这套题目我并不是很擅长. 可同学们 ...

  6. 2016.9.15初中部上午NOIP普及组比赛总结

    2016.9.15初中部上午NOIP普及组比赛总结 2016.09.15[初中部 NOIP普及组 ]模拟赛 又翻车了!表示时超和空超很可恨! 进度 比赛:AC+0+0+20=120 改题:AC+80+ ...

  7. 2016.9.10初中部上午NOIP普及组比赛总结

    2016.9.10初中部上午NOIP普及组比赛总结 链接:https://jzoj.net/junior/#contest/home/1340 好不爽!翻车了!不过排名差不多在中间偏上一点, 还好不是 ...

  8. 2016.9.3初中部上午NOIP普及组比赛总结

    2016.9.3初中部上午NOIP普及组比赛总结 链接:https://jzoj.net/junior/#contest/home/1339 这次真爽,拿了个第四!(我还被班主任叫过去1小时呢!) 进 ...

  9. 2016.8.19上午初中部NOIP普及组比赛总结

    2016.8.19上午初中部NOIP普及组比赛总结 链接:https://jzoj.net/junior/#contest/home/1338 这次总结发得有点晚啊!我在这里解释一下, 因为浏览器的问 ...

随机推荐

  1. JAVA大文件上传断点续传解决方案

    javaweb上传文件 上传文件的jsp中的部分 上传文件同样可以使用form表单向后端发请求,也可以使用 ajax向后端发请求 1.通过form表单向后端发送请求 <form id=" ...

  2. 文件选择对话框:CFileDialog

    程序如下: CString   FilePathName; //文件名参数定义 CFileDialog  Dlg(TRUE,NULL,NULL,                             ...

  3. “编程小白学python”阅读笔记

    今天在豆瓣搜索“python”关键字,搜到一本知乎周刊,读来觉得不错 编程小白学python ,作者@萧井陌, @Badger 书中提到的很多书,第一次看惊呆了,记录下来,希望每周回看此博文,坚持学习 ...

  4. Pollard-rho算法[因子分解算法]

    试除法:最简单的因数分解算法,从$ 2 $到$ \sqrt n $一个一个试. 试除法(改进):从$ 2 $到$ \sqrt n $挑素数一个一个试. 然而这样复杂度是相当高的. 生日悖论:指如果一个 ...

  5. 191121CSS

    一.CSS 1.css选择器 css选择器的使用方法 <!DOCTYPE html> <html lang="en"> <head> <m ...

  6. 通过tar包解压安装docker

    以下步骤在centos7和debian10中验证通过 1.通过官网下载安装包 wget https://download.docker.com/linux/static/stable/x86_64/d ...

  7. PHP基本语句

    语句分支语句if语句if if.........elseif.......else if.....else if 的嵌套switch语句 循环语句 for 循环 函数 函数的4要素::返回类型,函数名 ...

  8. 关于ArrayList的越界问题?

    大家都知道 ArrayList是自动扩容的. 那为什么会存在越界问题? 话不多说 上代码 package test; import java.util.ArrayList; public class ...

  9. 【flask】使用Flask-WTF处理表单

     我的理解是Flask-WTF与html文件的关系就如同SQLAlchemy与数据库之间的关系. 通过python Form类,生成html代码,并在html模板文件中通过{{}}变量的方式引用这些生 ...

  10. iOS 图表工具charts介绍

    charts是一个很好的绘图工具,功能非常强大,可以用来绘制折线,柱状图,饼状图,k线图,k线分时图,雷达图,气泡图等等,charts是一款仿照安卓 MPAndroidChart而来的一个基于swif ...