骗分技巧之打表出省一

2023-10-19 06:59
文章标签 技巧 骗分 打表出

本文主要是介绍骗分技巧之打表出省一,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

例题一

例题二 

例题一

P1044 [NOIP2003 普及组] 栈https://www.luogu.com.cn/problem/P1044当我们在考场上不知道卡特兰数,但我们可以骗分。

先写出以下代码:

#include<bits/stdc++.h>
using namespace std;
long long n, ans, now;
bool V[10];
void dfs(int stepu, int stepo) {if (stepu >= n and stepo >= n) {ans += (now == 0);return;}if (stepo > n or stepu > n) return;if (stepo < n and now) {now--;dfs(stepu, stepo + 1);now++;}if (stepu < n) {now++;dfs(stepu + 1, stepo);now--;}
}
int main() {ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);cin >> n;dfs(0, 0);cout << ans << endl;return 0;
}

关注到题目里写着 n <= 18

必定超时,但我们可以打表

依次运行n=1~18的答案得到下表:

n答案
11
22
35
414
542
6132
7429
81430
94862
1016796
1158786
12208012
13742900
142674440
159694845
1635357670
17129644790
18477638700

得到打表程序:

#include<bits/stdc++.h>
using namespace std;
long long arr[] = {0, 1, 2, 5, 14, 42, 132, 429, 1430, 4862, 16796, 58786, 208012, 742900, 2674440, 9694845, 35357670, 129644790, 477638700};
int main(){int n;cin >> n;cout << arr[n] << endl;return 0;
}

一提交发现:

例题二

[CSP-J 2022] 逻辑表达式[CSP-J 2022] 逻辑表达式icon-default.png?t=M85Bhttps://www.luogu.com.cn/problem/P8815?contestId=90215我考场上逻辑表达式的值会做,但后面的不会(谁叫我是XXS呢

但我也去打表了。

哈哈哈。

代码见下:

#include<bits/stdc++.h>
using namespace std;
string s;
int main() {freopen("expr.in","r",stdin);freopen("expr.out","w",stdout);cin >> s;if (s == "1") cout << "1\n0 0";else if(s == "0") cout << "0\n0 0";else if(s == "(1)") cout << "1\n0 0";else if(s == "(0)") cout << "0\n0 0";else if(s == "1&1") cout << "1\n0 0";else if(s == "1&0") cout << "0\n0 0";else if(s == "0&1") cout << "0\n1 0";else if(s == "0&0") cout << "0\n1 0";else if(s == "1|1") cout << "1\n0 1";else if(s == "1|0") cout << "1\n0 1";else if(s == "0|1") cout << "1\n0 0";else if(s == "0|0") cout << "0\n0 0";else if(s == "((1))") cout << "1\n0 0";else if(s == "((0))") cout << "0\n0 0";else if(s == "(1&1)") cout << "1\n0 0";else if(s == "(1&0)") cout << "0\n0 0";else if(s == "(0&1)") cout << "0\n1 0";else if(s == "(0&0)") cout << "0\n1 0";else if(s == "(1|1)") cout << "1\n0 1";else if(s == "(1|0)") cout << "1\n0 1";else if(s == "(0|1)") cout << "1\n0 0";else if(s == "(0|0)") cout << "0\n0 0";else if(s == "(1)&1") cout << "1\n0 0";else if(s == "(1)&0") cout << "0\n0 0";else if(s == "(0)&1") cout << "0\n1 0";else if(s == "(0)&0") cout << "0\n1 0";else if(s == "(1)|1") cout << "1\n0 1";else if(s == "(1)|0") cout << "1\n0 1";else if(s == "(0)|1") cout << "1\n0 0";else if(s == "(0)|0") cout << "0\n0 0";else if(s == "1&(1)") cout << "1\n0 0";else if(s == "1&(0)") cout << "0\n0 0";else if(s == "0&(1)") cout << "0\n1 0";else if(s == "0&(0)") cout << "0\n1 0";else if(s == "1|(1)") cout << "1\n0 1";else if(s == "1|(0)") cout << "1\n0 1";else if(s == "0|(1)") cout << "1\n0 0";else if(s == "0|(0)") cout << "0\n0 0";else if(s == "1&1|1") cout << "1\n0 1";else if(s == "1&1|0") cout << "1\n0 1";else if(s == "1&1&1") cout << "1\n0 0";else if(s == "1&1&0") cout << "0\n0 0";else if(s == "1&0|1") cout << "1\n0 0";else if(s == "1&0|0") cout << "0\n0 0";else if(s == "1&0&1") cout << "0\n1 0";else if(s == "1&0&0") cout << "0\n1 0";else if(s == "0&1|1") cout << "1\n1 0";else if(s == "0&1|0") cout << "0\n1 0";else if(s == "0&1&1") cout << "0\n2 0";else if(s == "0&1&0") cout << "0\n2 0";else if(s == "0&0|1") cout << "1\n1 0";else if(s == "0&0|0") cout << "0\n1 0";else if(s == "0&0&1") cout << "0\n2 0";else if(s == "0&0&0") cout << "0\n2 0";else if(s == "1|1|1") cout << "1\n0 1";else if(s == "1|1|0") cout << "1\n0 1";else if(s == "1|1&1") cout << "1\n0 1";else if(s == "1|1&0") cout << "1\n0 1";else if(s == "1|0|1") cout << "1\n0 1";else if(s == "1|0|0") cout << "1\n0 1";else if(s == "1|0&1") cout << "1\n1 1";else if(s == "1|0&0") cout << "1\n1 1";else if(s == "0|1|1") cout << "1\n0 1";else if(s == "0|1|0") cout << "1\n0 1";else if(s == "0|1&1") cout << "1\n0 0";else if(s == "0|1&0") cout << "0\n0 0";else if(s == "0|0|1") cout << "1\n0 0";else if(s == "0|0|0") cout << "0\n0 0";else if(s == "0|0&1") cout << "0\n1 0";else if(s == "0|0&0") cout << "0\n1 0";else if(s == "0&(1|0)|(1|1|1&0)") cout << "1\n1 2";else if(s == "(0|1&0|1|1|(1|1))&(0&1&(1|0)|0|1|0)&0") cout <<"0\n2 3";else if(s == "(((((1&(0&0|1))&(1|0|0)|1|(0&((0|(0|1)&1)|1|0))&((1|(1|1)&(1&0)&(1|1))|(1|0)|1)&((((((1|0)|0|0)&(1|((1&1&1)&(1|1))&0|0&0)|1)|1&0)&(0|0)|(0&(1|1))&1&(1|1)|0|1&0)&((0|1&0|1)&1)&(1|(1|0)&0))&(1&((1&0|1)|0&0)&((0|0)|0&0)|(1|((1|1)|1)&1&0)&1))|1|1)&((((((0&0)&(0|(0|1)|1&1)|0&0)|1)&(1|(1&0)&0))&(0|(0|0)|0)|(0|0)|0&1|((0&1|1)|0)&0)|((1|1|0&0)|(1&0&1)&(1&(1|0)|(0|1)&(1|0))|(((0&1)&0&1|(1&0)&0)|((0|1)|0)|1)|(1&1)&0)&(0&0)&(1|1))|((((0|0)|(0|0)|0)&0)&((0|(0|0)&0)|((1&(0|1&0)|1)|1)|0))&(1|0|1))|(0&((((1&0|1)&0&1|0|1)|1)|1)|((((((0&(0|0)|1)|1)|1|1)&(0|0)&1&(0&(1|1)|0|0&1)|1)&(((((1&1)&(0|1))&0&1)&0)&0&(1&1|0)|1|1)&((((1|1)|(0|1)&(1&0|0))&(((1|0|0)|0)&1|0)|1)&1|(((1|1|1)|1)|(0|0|1)&0)|0&1)&(0|0))&0&(0|1))&((1&((0|0)&1)&(0&0|1|1|1)|(0&(0|1)|0)&(((1|1)|0)|1)&1)&((1|((0|1)&0)&(0|1))|((((0&0)&0|1|1)&0)&0&0)&0&((1|0|0|0&0)|1|1))&0|(1&1&(1&(0|1&1)&0)&(0|0))&((0|1)|0&0&1)&(0&((0|1)|(1&1)&1|0))&(1|0)))|(((0|1)&(0|1)&1|(((0|0|0)&(((1|1)&1)&0|1&0))&((1|1)&1|1|1|0)|1)|(0&1|0&0&1&(0|1))&1)|1&((0&1|((1|0)|1|0)&((1|(0|1)&(0|0&0))&(0|1|0)|1&1|0|1&1)&1&(1&0)&1)|(1|1)|((0|1&0)|0)&1))|((0&(1|1&(1|0)|0|((1|1)|0)|0))&1)&((((0&(0|0|0))&1&0|0|1)|(0&0)&(((0&1)&0&0|0)|1)|0&1)|(((0&1|(0|0)&(0&1)&1)|(0|1)&0)&(1|0&1)|(0|(0|0)|0|1&1)&(1|1))&(((0|1)&(1&1)&0)&(0|0&1)|(0|1)&1&0)&((0|0&0)|1|1))|(((((0|0&0)&0&(0|1))&1)&1&1|((0|1)|0&1)&0)&(0|(0&1|0|1)&1)&(1|0)&(0&0|1)&(0|0))&(((1|1)&(1|(1&(1&0|((0|0)&0&1)&1))&(0|1))&(0|0)|0&((1|1)|0)|1|0)|(0|(0|1)&(1|0))&((0&1)&((1&0)&0)&1)&(1|1|0))|(((0|(0|(((0|1&1)|1)|0|1)|1)&((1&1&1)&0)&(1|0)&1)|((0&1&(1|1)|1&1)&(0|1&0)&(0|0&0)&0)&0&(1&((1|1)&0|0&1|1)|1))&((((0&0&0)&(1|0&0))&(0&0)&1)&0|1)&(0|1)&(0|0))&((((0|1)&((0|1&0&0|1)&(1|1)|1))&((1&0&0|1&0)|(1|0)|(0|1)|1&1)&((0&0|1&0|(0|0)&1)|1)|(((0&1)&(1|0&1&1))&1)&(((1|(0|0)|1)|(0&1)&((1|1)|1|0))|(0|0|0)&1&0)|(1|1&1|0)&((1|1)&0)&((1&0|1)|0))&((0|1&(0&0|0&0))|(1|1)&0|1))&((0&1)&((0|0&1)|1&1&((0|(1&1)&0)&0&1)&1)|(0&1)&0)|(0|(0|0&0)&0)&(0&1|0)&(1|1))&((1|1)&1|(((0|0)|0&0)|((1&1|(1&0)&1)|0)|((0&0)&0)&0&1|1|1)|(1|0)&0&0)") cout << "1\n22 36";else {cout << rand()%2<<endl;long long a = 0,b = 0;for(int i = 0; i < s.size(); i++) {if(s[i] == '|') a++;if(s[i] == '&') b++;}cout << rand()%(b/2)<< ' ' <<  rand()%(a/2) << endl;}return 0;
}

我的帖子:T3这样能拿20分吗

这篇关于骗分技巧之打表出省一的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/238128

相关文章

Pandas中多重索引技巧的实现

《Pandas中多重索引技巧的实现》Pandas中的多重索引功能强大,适用于处理多维数据,本文就来介绍一下多重索引技巧,具有一定的参考价值,感兴趣的可以了解一下... 目录1.多重索引概述2.多重索引的基本操作2.1 选择和切片多重索引2.2 交换层级与重设索引3.多重索引的高级操作3.1 多重索引的分组聚

Redis多种内存淘汰策略及配置技巧分享

《Redis多种内存淘汰策略及配置技巧分享》本文介绍了Redis内存满时的淘汰机制,包括内存淘汰机制的概念,Redis提供的8种淘汰策略(如noeviction、volatile-lru等)及其适用场... 目录前言一、什么是 Redis 的内存淘汰机制?二、Redis 内存淘汰策略1. pythonnoe

怎么关闭Ubuntu无人值守升级? Ubuntu禁止自动更新的技巧

《怎么关闭Ubuntu无人值守升级?Ubuntu禁止自动更新的技巧》UbuntuLinux系统禁止自动更新的时候,提示“无人值守升级在关机期间,请不要关闭计算机进程”,该怎么解决这个问题?详细请看... 本教程教你如何处理无人值守的升级,即 Ubuntu linux 的自动系统更新。来源:https://

将Python应用部署到生产环境的小技巧分享

《将Python应用部署到生产环境的小技巧分享》文章主要讲述了在将Python应用程序部署到生产环境之前,需要进行的准备工作和最佳实践,包括心态调整、代码审查、测试覆盖率提升、配置文件优化、日志记录完... 目录部署前夜:从开发到生产的心理准备与检查清单环境搭建:打造稳固的应用运行平台自动化流水线:让部署像

Java 枚举的常用技巧汇总

《Java枚举的常用技巧汇总》在Java中,枚举类型是一种特殊的数据类型,允许定义一组固定的常量,默认情况下,toString方法返回枚举常量的名称,本文提供了一个完整的代码示例,展示了如何在Jav... 目录一、枚举的基本概念1. 什么是枚举?2. 基本枚举示例3. 枚举的优势二、枚举的高级用法1. 枚举

不删数据还能合并磁盘? 让电脑C盘D盘合并并保留数据的技巧

《不删数据还能合并磁盘?让电脑C盘D盘合并并保留数据的技巧》在Windows操作系统中,合并C盘和D盘是一个相对复杂的任务,尤其是当你不希望删除其中的数据时,幸运的是,有几种方法可以实现这一目标且在... 在电脑生产时,制造商常为C盘分配较小的磁盘空间,以确保软件在运行过程中不会出现磁盘空间不足的问题。但在

Python中列表的高级索引技巧分享

《Python中列表的高级索引技巧分享》列表是Python中最常用的数据结构之一,它允许你存储多个元素,并且可以通过索引来访问这些元素,本文将带你深入了解Python列表的高级索引技巧,希望对... 目录1.基本索引2.切片3.负数索引切片4.步长5.多维列表6.列表解析7.切片赋值8.删除元素9.反转列表

Python中处理NaN值的技巧分享

《Python中处理NaN值的技巧分享》在数据科学和数据分析领域,NaN(NotaNumber)是一个常见的概念,它表示一个缺失或未定义的数值,在Python中,尤其是在使用pandas库处理数据时,... 目录NaN 值的来源和影响使用 pandas 的 isna()和 isnull()函数直接比较 Na

Oracle数据库执行计划的查看与分析技巧

《Oracle数据库执行计划的查看与分析技巧》在Oracle数据库中,执行计划能够帮助我们深入了解SQL语句在数据库内部的执行细节,进而优化查询性能、提升系统效率,执行计划是Oracle数据库优化器为... 目录一、什么是执行计划二、查看执行计划的方法(一)使用 EXPLAIN PLAN 命令(二)通过 S

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用