• Java练习题第二十七期:幸运的袋子


    作者:有只小猪飞走啦
    博客地址:

    前言

    本博客是小博主在做Java算法题的过程中一些觉得可以分享的题目,希望对你们有帮助,如果哪里写错了或者有更好的解法,都可以私聊我哈!我和你一起探讨!

    一,题目

    描述
    一个袋子里面有n个球,每个球上面都有一个号码(拥有相同号码的球是无区别的)。如果一个袋子是幸运的当且仅当所有球的号码的和大于所有球的号码的积。
    例如:如果袋子里面的球的号码是{1, 1, 2, 3},这个袋子就是幸运的,因为1 + 1 + 2 + 3 > 1 * 1 * 2 * 3
    你可以适当从袋子里移除一些球(可以移除0个,但是别移除完),要使移除后的袋子是幸运的。现在让你编程计算一下你可以获得的多少种不同的幸运的袋子。
    输入描述:
    第一行输入一个正整数n(n ≤ 1000) 第二行为n个数正整数xi(xi ≤ 1000)
    输出描述:
    输出可以产生的幸运的袋子数
    在这里插入图片描述

    二,解析

    每次从全集中选择若干元素(小球)组成子集(袋子)。对于任意两个正整数a,b如果满足 a+b>ab,则必有一个数为1.可用数论证明:设a=1+x,b=1+y,则1+x+1+y>(1+x)(1+y),—> 1>xy,则x,y必有一个为0,即a,b有一个为1.推广到任意k个正整数,假设a1,a2,…ak,如果不满足给定条件,即和sum小于等于积pi。如果此时再选择一个数b,能使其满足sum+b > pib,则,b必然为1,且为必要非充分条件。反之,如果选择的b>1,则sum+b <= pib,即a1,a2,…,ak,b不满足给定条件。因此,将球按标号升序排序。每次从小到大选择,当选择到a1,a2,…,ak-1时满足给定条件,而再增加选择ak时不满足条件(ak必然大于等于max(a1,a2,…,ak-1)),继续向后选择更大的数,必然无法满足!此时不必再
    继续向后搜索。如果有多个1,即当k=1时,sum(1)>pi(1)不满足,但下一个元素仍为1,则可以满足1+1>1
    1, 所以要判断当前ak是否等于1,如果等于1,虽然不能满足,组合的个数不能增加,但是继续向后搜索,仍然有满足条件的可能.对于重复数字,组合只能算一个,要去重。
    在这里插入图片描述

    三,代码

    import java.util
    • 相关阅读:
      前端进击笔记第二十二节 如何进行性能分析的自动化实现
      [附源码]Python计算机毕业设计出版社样书申请管理系统
      汽车租赁APP
      【HarmonyOS】鸿蒙开发之Video组件——第3.7章
      Spring事件监听机制源码解析
      全网最牛自动化测试框架系列之pytest(6)-Fixture(固件)
      C++初阶(stack+queue)
      php 进程通信系列 (四)共享内存
      egrep扩展正则表达式
      Golang笔记
    • 原文地址:https://blog.csdn.net/m0_62262008/article/details/127940831