洛谷P2638 安全系统

news/2025/2/8 16:02:51/

安全系统

题目描述

特斯拉公司的六位密码被轻松破解后,引发了人们对电动车的安全性能的怀疑。李华听闻后,自己设计了一套密码:

  • 假设安全系统中有 n n n 个储存区,每个储存区最多能存储存 2 2 2 种种类不同的信号(可以不储存任何信号)。有 0 0 0 1 1 1 这两种信号,其中 0 0 0 a a a 个, 1 1 1 b b b 个,单独一个 0 0 0 1 1 1 算一个信号。现要将这些信号储存在储存区中, 0 0 0 1 1 1 可以不用全部储存,一个储存区可以存放任意多个 0 0 0 和任意多个 1 1 1。一种不同的储存方案经过李华处理后就将是一串不同的密码。

现在给出 n , a , b n,a,b n,a,b,求可能的不同储存方案的个数。

输入格式

第一行:共 3 3 3 个整数, n , a , b n,a,b n,a,b

输出格式

第一行:一个整数,表示方案个数。

样例 #1

样例输入 #1

2 1 1

样例输出 #1

9

提示

所有 9 9 9 种方案如下:

储存区 1 1 1储存区 2 2 2
NULL \verb!NULL! NULL NULL \verb!NULL! NULL
0 0 0 NULL \verb!NULL! NULL
1 1 1 NULL \verb!NULL! NULL
NULL \verb!NULL! NULL 0 0 0
NULL \verb!NULL! NULL 1 1 1
0 , 1 0,1 0,1 NULL \verb!NULL! NULL
NULL \verb!NULL! NULL 0 , 1 0,1 0,1
1 1 1 0 0 0
0 0 0 1 1 1

对于全部数据, a , b ≤ 50 a,b\le 50 a,b50 n + a ≤ 50 n+a\le 50 n+a50 n + b ≤ 50 n+b\le 50 n+b50


upd 2022.10.22 \text{upd 2022.10.22} upd 2022.10.22:新增加一组 Hack 数据。

###### 解题心得:这道题我也想到了用组合数无奈实力有限不知道这么处理,跑去看了题解~~

题目分析:引用大佬题解

引用大佬题解
然后就是痛苦的高中组合数了,每次做这种题都很折磨!!! 本题用到了隔板法
在这里插入图片描述

注意:然后我们可以先用杨辉三角来算组合数,再来看一下数据范围。这里的组合数需要算到多大呢?容易看出最大总元素数(就是 C 的那个下标)是 n+max(a,b) - 1,因此需要用 unsigned long long来存数。

代码部分:

#include<bits/stdc++.h>
using namespace std;
typedef unsigned long long ULL;
const int N = 110;ULL c[N][N];
int n,a,b;
ULL ans;void Init()
{c[1][0] = 1,c[1][1] = 1;for(int i = 2; i < N; i++){c[i][0] = 1;for(int j = 1; j <= i; j++)c[i][j] = c[i - 1][j - 1] + c[i - 1][j];}
}int read()
{int s=0,f=1;char ch=getchar();while (ch<'0'||ch>'9'){if (ch=='-') f=-1;ch=getchar();}while (ch>='0'&&ch<='9'){s=s*10+ch-'0';ch=getchar();}return s*f;
}int main() {n = read(),a = read(),b = read();Init();for(int i = 0; i <= a; i++)for(int j = 0; j <= b; j++){ans += c[n + i - 1][n - 1] * c[n + j - 1][n - 1];}cout<<ans;return 0;
}

http://www.ppmy.cn/news/1570359.html

相关文章

嵌入式硬件篇---OpenMV串口通信json字符串

文章目录 前言第一部分:Json字符串通信协议优点缺点 Json优点缺点编码与解码 第二部分:UART串口通信UART常用函数注意 总结 前言 以上就是今天要讲的内容&#xff0c;本文简单介绍了Json字符串、UART串口通信。 第一部分:Json字符串 通信协议 在传统的单片机应用中&#xff…

Android ExpandableListView 详细用法全解析

引言 在 Android 开发中&#xff0c;列表展示是一种非常常见的交互形式。而 ExpandableListView 作为一种特殊的列表控件&#xff0c;它允许我们创建具有分组功能的列表&#xff0c;每个分组下还可以包含多个子项&#xff0c;并且分组可以展开和收缩&#xff0c;这大大增强了数…

【梦想终会实现】Linux驱动学习5

加油加油坚持住&#xff01; 1、 Linux驱动模型&#xff1a;驱动模型即将各模型中共有的部分抽象成C结构体。Linux2.4版本前无驱动模型的概念&#xff0c;每个驱动写的代码因人而异&#xff0c;随后为规范书写方式&#xff0c;发明了驱动模型&#xff0c;即提取公共信息组成一…

在 Elastic 中实施聚类工作流以提升搜索相关性

作者&#xff1a;来自 Elastic Gus Carlock 及 Kirti Sodhi 我们演示了如何利用 OpenAI text-ada-002 向量将自定义聚类模型集成到 Elastic Stack 中&#xff0c;从而简化 Elastic 生态系统内的工作流程。 在本文中&#xff0c;我们将演示如何通过利用示例文本数据集将自定义聚…

【Linux开发工具】包管理器yum和文本编辑器vim

目录 一、前言 二、Linux中的软件商店yum 1.三种安装软件的方式 2.yum的使用方法 三、Linux中的编辑器vim 1.vim的三种模式及切换 2.命令模式详解 3.底行模式详解 4.替换模式 5.视图模式 6.vim下的多线程操作 7.vim的配置 四、总结 一、前言 在初步认识了Linux的基…

windows11上,使用pipx安装Poetry,Poetry的安装路径是什么?

当使用 pipx 安装 Poetry 时&#xff0c;pipx 会将 Poetry 安装到一个独立的虚拟环境中&#xff0c;并将其可执行文件链接到一个集中的目录中。以下是 pipx 安装 Poetry 时的路径信息&#xff1a; 1. Poetry 的安装路径 pipx 会为每个工具&#xff08;如 Poetry&#xff09;创…

k8sollama部署deepseek-R1模型,内网无坑

这是目录 linux下载ollama模型文件下载到本地,打包迁移到k8s等无网络环境使用下载打包ollama镜像非k8s环境使用k8s部署访问方式非ollama运行deepseek模型linux下载ollama 下载后可存放其他服务器 curl -L https://ollama.com/download/ollama-linux-amd64.tgz -o ollama-linu…

开源CodeGPT + DeepSeek-R1 是否可以替代商业付费代码辅助工具

开源CodeGPT + DeepSeek-R1 是否可以替代商业付费代码辅助工具 背景与研究目的 在快速发展的软件开发领域,代码辅助工具已成为提高开发效率和质量的关键。然而,商业付费工具如通义灵码和腾讯AI代码助手,尽管功能强大,但其高昂的成本和许可证限制,使得许多企业寻求更具吸…