期中考总结&NOIP2017总结

2017年11月11日,我第二次参加NOIP普及组复赛。上一年,我的得分是250分,只拿到了二等奖。我便把目标定为拿到一等奖,考到300分以上。

早上8点多,我们去302教室,听同学讲考试注意事项(有十几条),有两条令我受益匪浅——要吃饱;不要定义与自带函数重名的变量或函数(如x0,y0什么的)。

我们看了自己的考试信息后,就上车了。11点多就到达广州了。

吃中午饭的地方是一间名叫都城快餐的快餐店,我们却吃了一个多小时的快餐(有人等饭等了四十多分钟)

吃完饭后,我们走去广州六中,接着在那里休息(睡午觉)。2点钟就去考场了。

比赛2点半开始,6点钟结束。开始考试后,我用了40分钟看了一下题目。

T1:

哇!好水呀!

直接输出\({\frac{2a}{10}+\frac{3b}{10}}+\frac{5c}{10}\)不就完事了吗?

这题不会那么水的!我又看了看题,确保万无一失,以防把这唾手可得的100分弄丢了。

然后就AC了。

T2:

嗯,挺水的。

一眼出正解——暴力!

我的方法就是暴力,只不过加了一点优化(因为比赛时我担心此题有坑)

考场AC!

PS:此题用字典树是最快的。

T3:

一开始想到了DFS,又想到了DP,到了动手做题前,才发现DP过不了,就打了个记忆化搜索。

相信许多人都觉得魔法特难搞,其实并不难。

通过找规律,我们不难发现,从有颜色的格子开始走,可以走到任意格子,不管它有没有颜色。

而没有颜色的格子却只能走到那些有颜色的格子上(不能连续两次用魔法)

那怎么计算使用魔法的花费呢?我发现,可以分成两种情况判断:



然后记录一下上一个格子坐标就好了。

考场AC!

T4:

这题我0分,题解见https://www.cnblogs.com/huangzihaoal/p/11154115.html


比赛结束后,我忐忑不安地离开考场。不知道今年我能考到多少分呢?应该是310~320吧(然而只拿了300分)!

晚饭我们不是在都城快餐吃了,我们去到了一间饭店吃。不知为何,老师点了特别多的菜,每一桌的菜数比人数还要多!

最后我们当然是没吃完的。有诗云:

锄禾日当午,汗滴禾下土。

谁知盘中餐,粒粒皆辛苦。

我的良心受到了谴责!


代码

T1:

#include<cstdio>
using namespace std;
int main()
{
freopen("score.in","r",stdin);
freopen("score.out","w",stdout);
int a,b,c;
scanf("%d%d%d",&a,&b,&c);
printf("%d\n",a/10*2+b/10*3+c/10*5);
return 0;
}

T2:

#include<cstdio>
using namespace std;
int a[1010],s[11];
void qsort(int l,int r)
{
int i=l,j=r,mid=a[(l+r)/2],t;
while(i<=j)
{
while(a[i]<mid) i++;
while(a[j]>mid) j--;
if(i<=j)
{
t=a[i];
a[i]=a[j];
a[j]=t;
i++;j--;
}
}
if(i<r) qsort(i,r);
if(l<j) qsort(l,j);
}
int main()
{
freopen("librarian.in","r",stdin);
freopen("librarian.out","w",stdout);
int n,q,i,j=0,need,len,k=1;
bool haveFind_theBook;
scanf("%d%d",&n,&q);
for(i=1;i<=n;i++) scanf("%d",&a[i]);
qsort(1,n);
for(i=0;i<11;i++) s[i]=1;
for(i=1;i<=n;i++)
{
while(a[i]>=k)
{
j++;s[j]=i;
k=k*10;
}
}
while(q--)
{
scanf("%d%d",&len,&need);
if(len==0)
{
printf("-1\n");
continue;
}
k=1;haveFind_theBook=false;
for(i=1;i<=len;i++) k=k*10;
for(i=s[len];i<=n;i++)
{
if(a[i]%k==need)
{
haveFind_theBook=true;
printf("%d\n",a[i]);
break;
}
}
if(!haveFind_theBook) printf("-1\n");
}
return 0;
}

T3:

#include<cstdio>
using namespace std;
#define maxlongint 0x7fffffff
const int dx[4]={1,0,-1,0};
const int dy[4]={0,1,0,-1};
int n,c[101][101],f[101][101];
void dfs(int x,int y,int cost,int X,int Y)
{
if(f[x][y]<=cost) return;
f[x][y]=cost;
int i,xx,yy;
for(i=0;i<4;i++)
{
xx=x+dx[i];yy=y+dy[i];
if(xx>0&&yy>0&&xx<=n&&yy<=n)
{
if(c[x][y]==0)
{
if(c[xx][yy]==0) continue;
else
{
if(c[X][Y]==c[xx][yy])
{
dfs(xx,yy,cost,1,1);
}
else dfs(xx,yy,cost+1,1,1);
}
}
else
{
if(c[xx][yy]==0)
{
dfs(xx,yy,cost+2,x,y);
}
else
{
if(c[x][y]==c[xx][yy])
{
dfs(xx,yy,cost,1,1);
}
else dfs(xx,yy,cost+1,1,1);
}
}
}
}
}
int main()
{
freopen("chess.in","r",stdin);
freopen("chess.out","w",stdout);
int m,i,j,x,y,z;
scanf("%d%d",&n,&m);
for(i=1;i<=m;i++)
{
scanf("%d%d%d",&x,&y,&z);
c[x][y]=z+1;
}
for(i=1;i<=n;i++)
{
for(j=1;j<=n;j++)
{
f[i][j]=maxlongint;
}
}
dfs(1,1,0,1,1);
if(f[n][n]==maxlongint) printf("-1\n");
else printf("%d\n",f[n][n]);
return 0;
}

T4:

#include<cstdio>
using namespace std;
#define maxlongint 1999999999//事实证明,用-maxlongint的效果最好
int f[500001],queue[500001],x[500001],s[500001];
int main()
{
freopen("jump.in","r",stdin);
freopen("jump.out","w",stdout);
int n,d,k,l=0,r=1000000000,mid,i,j,t,ans=-1,maxx,minn,head,tail,last;
bool bk,bz;
scanf("%d%d%d",&n,&d,&k);
for(i=1;i<=n;i++) scanf("%d%d",&x[i],&s[i]);
l=0;r=1000000000;
while(l<=r)
{
mid=(l+r)/2;
maxx=d+mid;bk=false;bz=true;
minn=d-mid;last=0;
if(minn<1) minn=1;
tail=head=1;
queue[1]=0;
for(i=1;i<=n;i++)
{
if(maxx>=x[i]&&minn<=x[i])
{
bz=false;
break;
}
}
if(bz)
{
l=mid+1;
continue;
}
for(i=1;i<=n;i++)
{
f[i]=maxlongint;
for(j=last+1;j<i;j++)
{
if(x[j]+minn>x[i]) break;
if(x[j]+maxx<x[i]) continue;
last=j;
if(f[j]==maxlongint) continue;
while(head<=tail&&f[queue[tail]]<=f[j]) queue[tail--]=0;
queue[++tail]=j;
}
while(head<tail&&x[queue[head]]+maxx<x[i]) head++;
if(x[queue[head]]+maxx<x[i]||x[queue[head]]+minn>x[i]) f[i]=maxlongint;
else f[i]=f[queue[head]]+s[i];
if(f[i]<maxlongint&&f[i]>=k)
{
bk=true;
break;
}
}
if(bk)
{
ans=mid;
r=mid-1;
}
else l=mid+1;
}
printf("%d\n",ans);
return 0;
}

NOIP2017普及组比赛总结的更多相关文章

  1. [NOIP2017普及组]跳房子(二分,单调队列优化dp)

    [NOIP2017普及组]跳房子 题目描述 跳房子,也叫跳飞机,是一种世界性的儿童游戏,也是中国民间传统的体育游戏之一. 跳房子的游戏规则如下: 在地面上确定一个起点,然后在起点右侧画 nn 个格子, ...

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

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

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

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

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

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

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

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

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

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

  7. 2016.8.18上午纪中初中部NOIP普及组比赛

    2016.8.18上午纪中初中部NOIP普及组比赛 链接:https://jzoj.net/junior/#contest/home/1336 翻!车!啦!好吧,那是因为大神归来. 进度: 比赛:AC ...

  8. 2016.8.17上午纪中初中部NOIP普及组比赛

    2016.8.17上午纪中初中部NOIP普及组比赛 链接:https://jzoj.net/junior/#contest/home/1335 本来觉得自己能考高分,但只得160分,并列第九.至少又挤 ...

  9. 2016.8.16上午纪中初中部NOIP普及组比赛

    2016.8.16上午纪中初中部NOIP普及组比赛 链接:https://jzoj.net/junior/#contest/home/1334 这次也翻车了,感觉比之前难多了. 辛辛苦苦改完了,太难改 ...

随机推荐

  1. sh_19_字符串拆分和拼接

    sh_19_字符串拆分和拼接 # 假设:以下内容是从网络上抓取的 # 要求: # 1. 将字符串中的空白字符全部去掉 # 2. 再使用 " " 作为分隔符,拼接成一个整齐的字符串 ...

  2. Harmonic Number (LightOJ 1234)(调和级数 或者 区块储存答案)

    题解:隔一段数字存一个答案,在查询时,只要找到距离n最近而且小于n的存答案值,再把剩余的暴力跑一遍就可以. #include <bits/stdc++.h> using namespace ...

  3. Java web 公文流转系统 完成结果

    河北金力集团公文流转系统 1.项目需求: 河北金力集团是我省机械加工的龙头企业,主要从事矿山机械制造及各种机械零部件加工.企业有3个厂区,主厂区位于省高新技术开发区,3个分厂分别在保定.邢台和唐山.为 ...

  4. ngx_http_auth_request_module 第三方认证

    shell > vim /usr/local/nginx-1.10.2/conf/vhost/auth.conf # 这是第三方认证服务器,认证逻辑使用的 PHP 代码 server { lis ...

  5. xcode6 如何编译64位iOS应用

    原文:http://mobile.51cto.com/hot-412500.htm 随着iPhone5S的推出,大家开始关心5S上所使用的64位CPU A7. 除了关心A7的性能以外,大家还会关心一个 ...

  6. POJ2942Knights of the round table

    这题第一次做的人一般是颓题解的. 首先我们转化一下问题,既然厌恶的人不能一起出席,是一种不传递关系,我们构建补图,这样补图的边表示两个骑士可以同时出席. 此时,由于只能有奇数个人参加,则我们要找出奇环 ...

  7. LeetCode 144. 二叉树的前序遍历(Binary Tree Preorder Traversal)

    题目描述 给定一个二叉树,返回它的 前序 遍历. 示例: 输入: [1,null,2,3] 1 \ 2 / 3 输出: [1,2,3] 进阶: 递归算法很简单,你可以通过迭代算法完成吗? 解题思路 由 ...

  8. 【java多线程】多线程中的long和double

    在看一些代码的时候,会发现在定义long型和double型的变量时,会在前面加上volatile关键字,当然也会看到在其它原子类型的变量前加上这个关键字,但这里要说的还是有区别的. 在java中,ja ...

  9. 在win10系统安装两个不同版本的mySQL数据库

    我们项目用的mySQL数据库,为了回家看代码方便,于是在本地安装mySQL数据库,一开始安装了比服务器mySQL5.7.24更高版本的mySQL8.0.11,结果项目启动报错,估计是版本太高项目中引入 ...

  10. ValueStack对象

    ValueStack, 即值栈对象. 值栈对象: 是整个struts数据存储的核心,或者叫中转站. 用户每次访问struts的action,都会创建一个Action对象.值栈对象.ActionCont ...