当前位置: 首页 > news >正文

2022蓝桥杯省赛——卡片

问题描述

小蓝有 k 种卡片, 一个班有 n 位同学, 小蓝给每位同学发了两张卡片, 一位同学的两张卡片可能是同一种, 也可能是不同种, 两张卡片没有顺序。没有两位同学的卡片都是一样的。

给定 n, 请问小蓝的卡片至少有多少种?

输入格式

输入一行包含一个正整数表示 n 。

输出格式

输出一行包含一个整数, 表示答案。

样例输入

6

样例输出

3

样例说明

小朋友们手中的卡片可能是: (1,1),(1,2),(1,3),(2,2),(2,3),(3,3)(1,1),(1,2),(1,3),(2,2),(2,3),(3,3) 。

评测用例规模与约定

对于 50% 的评测用例, 1≤n≤10^4 。

对于所有评测用例, 1≤n≤10^9 。

运行限制

  • 最大运行时间:1s
  • 最大运行内存: 256M

问题分析

这是一个组合数问题,需要注意的有两点:

  1. 两张同样的卡片也可以作为一种组合,所以跳出循环的条件是 c(k,2)+k>=n 。根据组合数的公式很容易用代码实现。
  2. 计算组合数的复杂度主要集中在求解阶乘的过程中。考虑到 n 的最大值为10^9,需要使用记忆化数组来缩短计算时间。在这类比赛中,程序处理千万级的运算量时已经很勉强了,所以我在这里将记忆化数组的长度设为10^7,即一千万。

 

 Python代码如下:

n=int(input())
dp=[-1 for i in range(10**7)]  # 阶乘数的记忆化数组# 阶乘
def fact(X):ans=1  # 阶乘结果x=Xwhile x>1:if dp[x]!=-1:  # 已知x的阶乘ans*=dp[x]dp[X]=ansreturn anselse:ans*=xx-=1dp[X]=ansreturn ans# 组合数
def c(n,m):return fact(n)/(fact(m)*fact(n-m))k=0
while c(k,2)+k<n:k+=1print(k)

可惜的是,由于无法将记忆化数组的长度设为10^9,通过率只有80%。读者如发现不足之处,欢迎批评指正。

 

http://www.lryc.cn/news/56628.html

相关文章:

  • 数据结构-快速排序
  • WuThreat身份安全云-TVD每日漏洞情报-2023-04-10
  • IDEA中查看源码点击Download Sources时出现Cannot download sources的问题复现及解决
  • R+VIC模型融合实践技术应用及未来气候变化模型预测/SWAT/HSPF/HEC-HMS
  • Python 02 数据类型(04元组)
  • WMS:入库库作业流程状态定位
  • 蓝易云:Linux系统【Centos7】如何配置完整的CC攻击防护策略
  • 编解码持续升级,「硬」实力铸就视频云最优解
  • 贵金属技术分析的止损保护
  • Python 进阶指南(编程轻松进阶):三、使用 Black 工具来格式化代码
  • 计算机应用辅导大纲及真题
  • 【Go基础】一篇文章带你全面了解学习—切片
  • 2022国赛28:centos8.5离线安装docker
  • JVM专题
  • 蓝桥杯模板题目
  • SAP IDT - Building Data Foundation
  • 【Python】【进阶篇】三、Python爬虫的构建User-Agnet代理池
  • 数据结构.双链表的各种操作
  • 去年12月被无情辞退,三个月后我携手自动化测试神技王者归来
  • 区块链技术之共识机制
  • SpringCloud断路器——Hystrix
  • 分布式 - 分布式体系架构:集群和分布式
  • NodeJs常用内置模块
  • 4.0 功能抢先看 | 读懂一个项目的研发效能 之 项目人效
  • Object方法
  • 042:cesium加载Eris地图(多种形式)
  • 第十四届蓝桥杯大赛软件赛省赛(C/C++B组)
  • Python生成随机验证码
  • Longitudinal Change Detection on Chest X-rays Using Geometric Correlation Maps
  • 5年功能测试的一些心得