骗分导论新版

目录:

1. 骗分是什么

2. 青铜:打表,最实用的骗分

3. 白银:无解最好玩

4. 黄金:小学数学找规律

5. 铂金:千能的模拟

6. 钻石:爆搜,最强的骗分技巧

7. 王者:听天由命

8. 天神:贪心的合并

9. 上帝:报复性心理——死循环

10. 实战演练

11.结语

1.骗分是什么

真香定律中说道,做出超范围的事总会遭受他人打脸,所以,骗分也是有坏处的。

骗分,顾名思义,不会写的题骗几分,积小成多,很可能骗分的蒟蒻就比认真做题

的蒟蒻高出几分。接下来,就让我们学习骗分吧!

2.青铜:打表,最实用的骗分

打表是性价比比较高的骗分技巧。在赛场上的最后时刻,选择打表准没错。

1)样例——白送分

很多时候,样例是做题时的帮手,他可以帮助判断你的代码是否有明显错误,也同

样可以用来骗分。美国比赛USACO当中,样例必须是第一个测试数据。具体操作贼简

单,不讲了。

2)数学时间

有时候,关于数学的题目,且数据范围小,就直接把所有情况动手算出来,if-else直接输出。

让我们来看一道例题

这题主要应用到栈,但是许多蒟蒻不会,只好骗分,那么这题怎么骗分呢?

我们定睛一看:n≤18n≤18

我天,真是的,这也太小了吧!

所以我们直接算算就算出来了。

int a[18]={1,2,5,14,42,132,429,1430,4862,16796,58786,208012,742900,2674440,9694845,35357670,129644790,477638700};

cin>>n;
cout<<a[n-1];

当然,直接就AC了。

3)打表的结论

打表实际上代码量有时较多,但是思考比较少,属于性价比较高的一种骗分方法。

3.白银:无解最好玩

接下来的这一章是所有蒟蒻最喜欢的:无解。话不多说,先来上例题:P1078文化之旅

这是非常好的一个利用无解骗分的题目,对蒟蒻们来说,这道绿题有点难,但是请

看他的最后一句话:

           一个整数,表示使者从起点国家到达终点国家最少需要走的距离数(如果无解则输出-1)

看见没有!无解输出-1!

所以只要输出-1就可以得到10分,甚至20,30分!

看看结果就知道了。

怎么样,是不是很神奇!!!!!!!!

这种方法也可以用在输出yes和no的情况当中,或者是只有两三种输出文本的情况里。

那么,我们这一章就讲到这里。

4.黄金:小学数学找规律

首先声明:本节讲的规律不是正当的算法规律,而是数据的特点。


例题

如果不看题目,你会发现,这么一个算式,怎么算啊!

没事,你要用到找规律。

我们可以看到给了一组样例,好嘛,找不了规律。

那么这就要考验数学了,只需要用纸和笔算出来一两组小数据的结果,就能很容易发现这是斐波那契数列了。

其实就这么简单。

别看找规律麻烦,真正要用到它的时候就能派上大用场!

当然,找规律是所有的骗分技巧中最不实用的一种方法,他只能在合适的时候用,

例如斐波那契数列这道题就适用,文化之旅就不好用了。所以一定要谨慎地使用找规律。

某些题目会给你很多样例,你就可以观察他们的特点了。有时,数据中的某一个 (或几个)数,能通过简单的关系直接算出答案。

只要你找到了规律,在很多情况下你都能得到可观的分数。

这样的题目大多出现在CF、AtcoderNOI或更高等级的比赛中,本人蒟蒻一个,就不举例了。传说某人去省选时专门琢磨数据的规律,结果有一题得了30分。

那么这一章就到此结束了。

5.铂金:千能的模拟

本章我们要进入算法了。

请蒟蒻中的蒟蒻自行退出。

正文:

模拟是一种朴素算法,他在骗分里却很实用。

他主要是骗一些高级数据结构的分,最常见的就是线段树。

那么我们就来看一道不在洛谷上的有技术含量但是能用模拟骗分的USACO线段树题目。

  排 队(USACO 2007 January Silver)

  【问题描述】

  每天,农夫约翰的N(1≤N≤50000)头奶牛总是按同一顺序排好队,有一天,约翰决定让一些牛玩一场飞盘游戏(Ultimate Frisbee),他决定在队列里选择一群位置连续的奶牛进行比赛,为了避免比赛结果过于悬殊,要求挑出的奶牛身高不要相差太大。

  约翰准备了Q(1≤Q≤200000)组奶牛选择,并告诉你所有奶牛的身高Hi(1≤ Hi ≤106)。他想知道每组里最高的奶牛和最矮的奶牛身高差是多少。

  注意:在最大的数据上,输入输出将占据大部分时间。

  【输入】

  第一行,两个用空格隔开的整数N和Q。 第2到第N+1行,每行一个整数,第i+1行表示第i头奶牛的身高Hi 第N+2到第N+Q+1行,每行两个用空格隔开的整数A和B,表示选择从A到B的所有牛(1 ≤ A ≤ B ≤ N)

  【输出】

  共Q行,每行一个整数,代表每个询问的答案。

  输入样例 输出样例

  6 3

  1

  7

  3

  4

  2

  5

  1 5

  4 6

  2 2 6

  3

  0

这道题一瞅就很难,我们蒟蒻不能硬啃。

我们来看看这道题怎么骗分。

找规律找不了,没有无解操作。

难道只能打表吗?

然而我们发现,这题是个线段树题,所以我们可以用模拟来骗分!

所以,我们只需要写一个程序,模拟程序,40-50分就有了!

for(int i=1;i<=q;i++){
  scanf(“%d%d”,&a,&b);
  int min=INT_MAX,max=INT_MIN;
  for(int i=a;i<=b;i++){
    if(h[i]<min)min=h[i];
    if(h[i]>max)max=h[i];
    }
   printf(“%d\n”,max-min);
}

搞定了!50分!

那么我们这章就到这儿了。

6.钻石:爆搜,最强的骗分技巧

欢迎来到爆搜这章。

爆搜,顾名思义,暴力枚举和搜索。

1)暴力枚举

暴力枚举不用说,三连击是一道很好的练习题。

那我们怎样用暴力枚举骗分呢?这块就不上代码了,累了

首先我们要清楚,暴力枚举只有在有思路的时候用。

暴力枚举一般用来骗什么分呢?有三种。

 1.搜索

 2.DP

 3.所有只能看明白有思路不会写的题目

所有的题有思路不会写的时候,不用想那些类似贪心、dp这类高级算法,用暴力直接求得分,有时间再钻研。

2)万能DFS

搜索里有DFS和BFS,但是BFS不适合骗分。

DFS是搜索中的重要算法,包括着回溯,但我们看来,图论神马的都是浮云,关键就是如何骗分。

DFS对于骗分是至关重要的。比如说,一些dp,可以DFS;数论,可以DFS;剪枝的题,更能DFS。下面有一道dp例题

看到没!30%是10以内的!

我们的DFS就要瞄准这里。

就像这样:

void DFS(int d,int c){
if(d==n){
    if(c>ans)ans=c;
    return;
}
DFS(d+1,c+w[i]);
DFS(d+1,c);
}

那么这一章就到此结束了。

7.王者:听天由命

1)随机数

如果你觉得你的人品很好,可以试试这一招——输出随机数。

先看一下代码:

#include<stdlib.h>
#include<time.h>
//以上两个头文件必须加
srand(time(NULL));
//输出随机数前执行此语句
printf(“%d”,rand()%X);
//输出一个0~X-1的随机整数。

这种方法适用于输出一个整数(或判断是否)的题目中,答案的范围越小越好。让老天爷决定你的得分吧。

据说,在NOIP2013中,有人最后一题不会,愤然打了个随机数,结果得了70分啊!!

2)蒙的基本对

让我们来看看这道

发现:只有jolly和notjolly两种,而满足条件的几率很小,那我们就直接输出notjolly就行了啊!

像这样:

#include <bits/stdc++.h>
using namespace std;
int main(){
    cout<<"Not jolly";
    return 0;
}

最后竟然得了50分

那么这一章就到此结束了。

8.天神:贪心的合并

1)贪心算法

dp——动态规划,是一种很难的算法。你做了1000道dp,第1001道还是不会。

考场上遇到dp我们要怎么做呢?

首先需要做的就是:贪心。

在这里声明:不要害怕没过样例,直接去测试就好了。

利用贪心,谁最大就用谁,最多能得到30分。

2)合并

我们已经学了很多骗分方法,但他们中的大多效率并不高,一般能骗10~20分。这不

能满足我们的骗分要求。

然而,我们可以合并骗分的程序。举个最简单的例子,有些含有无解情况的题目,

它们同样有样例。我们可以写这个程序:

if(是样例)cout<<样例;

else cout<<-1;

这样也许能变10分为20分,甚至更多。

当然,合并骗分方法时要注意,不要重复骗同一种情况,或漏考虑一些情况。

大量能骗分的问题都能用此法,大家可以试试用新方法骗文化之旅

3)C++党的福利——STL

快速排序是一个经典算法,也是C++党的经典福利。他们有这样的代码:

#include<algorithm>//这是必须的

sort(A,A+n);//对一个下标从0开始存储,长度为n的数组升序排序

就这么简单,完成了P党一大堆代码干的事情。

C++里还有一种东西,叫vector容器。它可以随着元素的数量而改变大小。它其实就是数组,却比数组强得多。

下面看看它的几种操作:

vector<int> V;//定义

V.push_back(x);//末尾增加一个元素x

V.pop_back();//末尾删除一个元素

V.size();//返回容器中的元素个数

它同样可以使用下标访问。(从0开始)

那这一章就介绍完了。

9.上帝:报复性心理——死循环

至此,我已介绍完了我所知的骗分方法。如果上面的方法都不奏效,我也无能为

力。但是,我还有最后一招——

有句古话说:“宁为玉碎,不为瓦全”。我们蒟蒻也应有这样的精神。骗不到分,

就报复一下,卡评测以泄愤吧! 卡评测主要有两种方法:一是死循环,故意超

时;二是进入终端,卡住编译器。 先介绍下第一种。代码很简单,请看:

while(1);

就是这短短一句话,就能卡住评测机长达10s,20s,甚至更多!

对于测试点多、时 限长的题目,这是个不错的方法。

第二种方法也很简单,但危害性较大,建议不要在重要比赛中使用,

否则可能让你追悔莫及。它就是:

include<con> //Windows系统中使用
include</dev/console>//Linux系统中使用

它非常强大,可以卡住评测系统,使其永远停止不了编译你的程序。

唯一的解除方法是,工作人员强行关机,重启,重测。

当然,我不保证他们不会气愤地把你的成绩变成0分。请慎用此方法。

10.实战演练

下面我们来做一些习题,练习骗分技巧。

我们来一起分析一下NOIP2013普及组的试题吧。

第一题

第二题

第三题

第四题

第1题,太弱了,蒟蒻都能做,不用骗,得100分。

第2题,数据很大,但是可以直接输入一个数,输出它mod 10000的值。得10分。

第3题,是一道非常基础的DP,但对于不知DP为何物的蒟蒻来说,就使用暴力算法(即DFS)。得20分。

第4题,我们可以寻找一下数据的规律,你会发现,在所有样例中,M值即为答案。所以直接输出M,得10分。

这样下来,一共得140分,比一等分数线还高20分!你的信心一定会得到鼓舞的。这就是骗分的神奇。

11.结语

骗分是蒟蒻的有力武器,可以在比赛中骗得大量分数。

相信大家在这个博客中收获了很多,希望本帖子能帮助你多得一些分。

但是,最后我还是要说一句:

只有做到不骗分,才是最好的骗分。

作者:ImNot6Dora

  • 9
    点赞
  • 36
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值