119149_1125*2436

119149_1125*2436题意理解:http://acm.timus.ru/problem.aspx?space=1&num=1142有N个对象,问有多少种关系?问题分析:用动态规划做:f(a,b)表示a个对象分成b组的分法。b组的意思是a个对象放到b个篮子里,每个篮子的对象之间是相等关系。初始值:f(0,0)=1;f(0,1…N)=0;f(1…N,0)=0递归式:f(a,b)=f(…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

题意理解:

http://acm.timus.ru/problem.aspx?space=1&num=1142

有N个对象,问有多少种关系?

问题分析:

用动态规划做:f(a,b) 表示a个对象分成b组的分法。b组的意思是a个对象放到b个篮子里,每个篮子的对象之间是相等关系。

初始值:

f(0,0) = 1; f(0,1…N) = 0; f(1…N, 0) = 0

递归式:

f(a,b) = f(a-1,b) * b + f(a-1, b-1)

f(a-1,b) * b 表示已知a-1个对象放到b个组中,再多一个对象可以放到b组任意一组中,共有b种方法;

f(a-1,b-1) 表示已知a-1个对象放到b-1个组中,再多一个对象时,要保证有b组,那只有将多的一个对象独立成组才可以。

这样,解决了N个对象分成b组的分法,分成b组后,关系是排列数,所以求b组的全排列值,有几组就是组数的阶乘,对于N个对象,它的关系数为f(N,1) * 1! + f(N,2) * 2! + f(N,3) * 3! +… + f(N,N) * N!

其他:

此题一开始使用硬分析,发现无法穷尽2个等于的情况。学到的一点就是脑子不要太累,太累的方法一定不是好方法,管理自己做题的脑力,尽可能思考用简洁有效的思路。

代码链接:

https://github.com/xierensong/learngit/blob/master/timus/t1142.cpp

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/188320.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • python 类中的方法

    python 类中的方法

    2021年6月19日
    70
  • mybatis的resultType integer(resultmap标签详解)

        在官方文档中对resultType做了如下介绍:从这条语句中返回的期望类型的类的完全限定名或别名。注意如果是集合情形,那应该是集合可以包含的类型,而不能是集合本身。使用resultType或resultMap,但不能同时使用。mybatis中resultType可选类型:1,java的基础类型及其包装类int,double和java.lang.Integer,java…

    2022年4月13日
    75
  • 微博用户洞察_实现一个观察者模式

    微博用户洞察_实现一个观察者模式观察者模式:当对象间存在一对多关系时,则使用观察者模式(ObserverPattern)。比如,当一个对象被修改时,则会自动通知它的依赖对象。观察者模式属于行为型模式。观察者模式定义了对象间的一种

    2022年8月6日
    3
  • html表单提交_html表单标签有哪些

    html表单提交_html表单标签有哪些1.表单属性设置<form>标签表示表单标签,定义整体的表单区域action属性设置表单数据提交地址method属性设置表单提交的方式,一般有“GET”方式和“POST”方式,不区分大小写2.表单元素属性设置name属性设置表单元素的名称,该名称是提交数据时的参数名value属性设置表单元素的值,该值是提交数据时参数名所对应的值3.示例代码<formaction=”https://www.baidu.com”method=”GET”>

    2022年9月26日
    0
  • 学生认证,专业版pycharm

    学生认证,专业版pycharm学生认证pycharm学习自https://blog.csdn.net/qq_36667170/article/details/79905198感谢分享以下记录下自己的过程1、https://www.jetbrains.com/pycharm/buy/?fromIDE#discounts?billing=yearly页面现在变成这样了2、选择Forstudentsandteachers下的learnmore3、Applynow4、填写表单,(一定要是教育邮箱,可以在学校

    2022年8月29日
    1
  • Vue学习之基础入门「建议收藏」

    Vue学习之基础入门「建议收藏」Vue学习之基础入门

    2022年4月23日
    54

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号