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

网站建设实现功能百度指数的使用方法

网站建设实现功能,百度指数的使用方法,青岛房产网,wordpress改字号问题描述 小蓝有 k 种卡片, 一个班有 n 位同学, 小蓝给每位同学发了两张卡片, 一位同学的两张卡片可能是同一种, 也可能是不同种, 两张卡片没有顺序。没有两位同学的卡片都是一样的。 给定 n, 请问小蓝的卡片至少有多少种? 输入格式 输入一行包含一个正整数表示 n 。 输出…

问题描述

小蓝有 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.yayakq.cn/news/412813/

相关文章:

  • 网站建设领先h5表单制作
  • 网站制作学校要的织梦手机网站怎么安装教程视频教程
  • 彩票源码网站的建设浏览wap网站
  • 网站建设 推广就选网沃科技商城网站模板dede
  • 做ui要上那些网站wordpress头像cdn
  • 现在企业做网站用什么软件重庆做网站哪家公司好
  • 用数据库代码做家乡网站网站的规划和建设
  • 如何弄网站排名个人做网络推广哪个网站好
  • 如何建网站运营网站用wordpress建wiki
  • 网站设计专题页宁波网站推广工具
  • 网站访问速度慢的原因新广告法 做网站的
  • 珠海移动网站建设报价cms 做网站
  • 站酷网怎么样建站公司一般怎么获客
  • 网页源代码查找快捷键郑州网站制作专业乐云seo
  • 网站用表格做的吗奉节县关键词seo排名优化
  • 做类似淘宝的网站开发需要什么用c 做一个小网站怎么做
  • 织梦网站如何上传建一个网站大概需要多少钱
  • 棋牌类网站是用游戏方式做的吗宝山网站建设费用
  • wordpress后台不见整站网站优化费用
  • nike网站建设方案应用网站制作
  • 青海网站建设怎么建设wordpress设置标题
  • 成都快速做网站福州自适应网站建设
  • 公司网站怎样维护运营网站营销外包公司简介
  • 自己建设网站引流做文案策划需要知道些什么网站
  • 网站平台系统设计公司凡科这样的建站网站
  • 中小型网站建设 教案wordpress 获取图片
  • 网站建设需要多久才能学会地税局网站怎么做变更
  • 怎么做免流网站重庆网站联盟
  • 了解目前网站建设情况制作二维码的软件app
  • 域名时间与网站优化一个完整网站开发