华为od-C卷200分题目 - 1分月饼

华为od-C卷200分题目 - 1分月饼

题目描述

中秋节,公司分月饼,m个员工,买了n个月饼,m<=n,每个员工至少分1个月饼,但可以分多个,
单人分到最多月饼的个数是Max1,单人分到第二多月饼个数是Max2,Max1-Max2<=3,单人分到
第n-1多月饼个数是Max(n-1),单人分到第n多月饼个数是Max(n),Max(n-1)-Max(n)<=3问有
多少种分月饼的方法?输入描述
每一行输入m n,表示m个员工,n个月饼,m<=n输出描述
输出有多少种月饼分法示例1
输入:
2 4输出:
2说明:
分法有2种
4=1+3
4=2+2
注意:1+3和3+1算一种分法
示例2
输入:
3 5输出:
2说明:
5=1+1+3
5=1+2+2
示例3
输入:
3 12输出:
6说明:
满足要求的有6种分法:
12=1+1+10(Max1=10,Max2=1,不满足要求)
12=1+2+9(Max1=9,Max2=2,不满足要求)
12=1+3+8(Max1=8,Max2=3 不满足要求)
12=1+4+7(Max1=7,Max2=4,Max3=1, 满足要求)
12=1+5+6(Max1=6,Max2=5,Max3=1,不满足要求)
12=2+2+8(Max1=8,Max2=2,不满足要求)
12=2+3+7(Max1=7,Max2=3,不满足要求)
12=2+4+6(Max1=6,Max2=4,Max3=2,满足要求)
12=2+5+5(Max1=5,Max2=2,满足要求)
12=3+3+6(Max1=6,Max2=3,满足要求)
12=3+4+5(Max1=5,Max2=4,Max3=3,满足要求)
12=4+4+4(Max1=4,满足要求)

题解

    import java.util.LinkedList;import java.util.Scanner;public class Main {static LinkedList<Integer> list;static int res;static int n, m, base;public static void main(String[] args) {Scanner sc = new Scanner(System.in);n = sc.nextInt();m = sc.nextInt();if(n == 1 ) {System.out.println(1);return;}base = 1;  int least = 3 * n * (n - 1) / 2;  while (base * n + least < m) {base++;}list = new LinkedList<>();res = 0;distribution(0, m);System.out.println(res);}public static void distribution(int index, int sum) {if (index == n - 1) {// 前一个树和最后一个数的差值不能超过3,最后一个数不能为负if (sum >= 0 && sum <= list.get(index - 1) + 3) {res++;}return;}int last, end;if (index == 0) {last = base;        // 如果是第一个数,则从保底开始end = sum / n;        // 第一个数最大为平均分配的大小}else {last = list.get(index - 1); //不是第一个数则从前一个数的最大值end = Math.min(last + 3, sum / (n - index));// 最大值为剩下的人平均分配的平均数和上个数最大值加三中的最小值}for (int i = last;i<= end;i++ ) {list.add(i);distribution(index + 1, sum - i);list.remove(index);}}}

思路:

base * n + least < m

int least = 3 * n * (n - 1) / 2;

分的方式:基础的保底 + 后续的分配,基础的保底就是base * n

base 代表每个人至少分1个月饼,base至少为1

去掉保底部分后剩下的,最大值是等差数列,当你人数确定时,那么最大等差数列就确定了,如果是3 人,则去掉保底部分最大就是9(0 + 3 + 6)。

我们为了防重和方便计算,所以我们第一个数除去保底始终为0

举例3人12月饼和3人13月饼

3人12月饼:减去3个保底,9满足等差数列 ;(3人,12月饼 结果为6)

3人13月饼,减去3个保底,分配的情况为(1, 3, 6)。

那么将保底上升到2,需要计算的情况变为(0, 2, 5); ( 3人,13月饼 结果为5)

以3人为例只要数量超过3人的等差数列9,则可以将多的作为保底,化简问题

所以等差数列部分固定,找到最大的保底数,最大的保底数作为第一个数的最小值

按照等差数列的公式:

(A1 + An) * (n) / 2 => 可以得到 (0 + (0 + (n - 1) * d) * n / 2 => (n - 1) * n * 3 / 2

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/28461.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Flutter 实现StackAllocator简化FFI局部变量的内存管理

文章目录 前言一、为何简化&#xff1f;1、通常做法2、简化 二、完整代码三、使用示例1、局部内存管理2、支持嵌套 总结 前言 使用Flutter通过FFI调用c库的时候&#xff0c;经常需要传字符串或者一些指针变量&#xff0c;这里变量通常都是局部变量&#xff0c;在一个代码块运行…

Spock mock私有方法

mock私有方法 ‍ 被测试的方法是MiddleGroundAppListBO​类下的getPromptIdKeyAppPromptInfoMap方法 private Map<Long, AppPromptInfoModel> getPromptIdKeyAppPromptInfoMap(String cubeAppIdentity) {List<AppPromptInfoDO> promptByApp knowledgeCubeQueryR…

轻松实现服务器事件主动推送到web端!Spring SseEmitter 详解

SseEmitter 是 Spring Framework 中用于服务器发送事件&#xff08;Server-Sent Events, SSE&#xff09;的类。SSE 是一种允许服务器推送更新到客户端的技术&#xff0c;通常用于实时更新的场景&#xff0c;如股票价格、实时消息、游戏状态等&#xff0c;又或者想要实现像Chat…

Vue52-scoped样式

一、scoped样式的作用 1-1、scoped样式的作用 vue中组件的样式都是汇总到一起的。容易出现一个问题&#xff1a;类名冲突。 示例&#xff1a; school和student组件的类名都叫demo&#xff0c;则student的样式将覆盖school的样式&#xff0c;因为App.vue中&#xff0c;先引入的…

Kubernetes (K8s) 和 Spring Cloud 的区别

Kubernetes (K8s) 和 Spring Cloud 是两种常用的云原生技术&#xff0c;它们在微服务架构和云计算领域中扮演着重要的角色。尽管两者都有助于开发和部署微服务&#xff0c;但它们的功能和目标存在显著差异。本文将详细讨论 Kubernetes 和 Spring Cloud 的区别&#xff0c;从它们…

NLP主流大模型如GPT3/chatGPT/T5/PaLM/LLaMA/GLM的原理和差异有哪些-详细解读

自然语言处理&#xff08;NLP&#xff09;领域的多个大型语言模型&#xff08;如GPT-3、ChatGPT、T5、PaLM、LLaMA和GLM&#xff09;在结构和功能上有显著差异。以下是对这些模型的原理和差异的深入分析&#xff1a; GPT-3 (Generative Pre-trained Transformer 3) 虽然GPT-4…

Rocky Linux安装Docker

简介&#xff1a; Red Hat Enterprise Linux (RHEL): RHEL 是由 Red Hat 公司开发和维护的企业级操作系统。 它是基于开源社区的 Fedora 项目&#xff0c;但提供了商业支持和服务&#xff0c;面向企业用户。 RHEL 提供了稳定、可靠和高性能的操作环…

理解JSP底层

import java.net.URLDecoder;public class login_jsp{//JSP的9大内置对象private JSPWriter out;//当前JSP输出流对象private HttpServletRequest request;//请求对象private HttpServletResponse response;//响应对象private HttpSession session;//会话对象private ServletCo…

【Python数据分析】Pandas_Series如何转变为DataFrame

1.使用 pd.DataFrame()构造函数 可以使用pd.DataFrame()构造函数将 Series 转换为 DataFrame。在构造函数中&#xff0c;将 Series 作为一个列传递给 DataFrame&#xff0c;并且可以通过指定列名来为 DataFrame 的列命名。 代码示例&#xff1a; import pandas as pd data[1…

sklearn 基础教程

scikit-learn&#xff08;简称sklearn&#xff09;是一个开源的机器学习库&#xff0c;它提供了简单和有效的数据分析和数据挖掘工具。sklearn是Python语言中最重要的机器学习库之一&#xff0c;广泛用于统计学习和数据分析。 以下是scikit-learn的基础教程&#xff0c;帮助您开…

【Python高级编程】用 Matplotlib 绘制迷人的图表

用 Matplotlib 绘制迷人的图表 引言 Matplotlib 是 Python 中广泛使用的绘图库&#xff0c;用于创建各种图表和可视化。本文将逐步指导您使用 Matplotlib 绘制基本图表&#xff0c;包括折线图、条形图和散点图。 安装 Matplotlib 使用 pip 安装 Matplotlib&#xff1a; pi…

存储器的性能指标以及层次化存储器

存储器的性能指标 存储器有三个性能指标&#xff1a;速度、容量和位价&#xff08;每位价格&#xff09; 1.存储速度 &#xff08;1&#xff09;存取时间 想衡量存储速度&#xff0c;最直观的指标就是完成一次存储器读写操作所需要的时间&#xff0c;这叫做存取时间&#x…

Spring运维之boo项目表现层测试加载测试的专用配置属性以及在JUnit中启动web服务器发送虚拟请求

测试表现层的代码如何测试 加载测试的专用属性 首先写一个测试 假定我们进行测试的时候要加一些属性 要去修改一些属性 我们可以写一个只在本测试有效的测试 写在配置里 测试 打印输出 我们把配置文件里面的配置注释掉后 我们同样可以启动 package com.example.demo;impo…

【数组基础知识】

二维数组 我的理解是&#xff0c;如果内层有值&#xff0c;外层打印就是地址值。如果内层没值&#xff0c;外层打印就是null。 int[][]a new int [3][]; 这样打印a[0]的时候是null。 打印a[0][0]会报错。 int[][]a new int [3][1]; 这样打印a[0]的时候是地址值。 打印a…

分布式事务之TCC

一、 实现一个分布式事务 TCC&#xff08;Try-Confirm-Cancel&#xff09;模式是一种常见的分布式事务解决方案&#xff0c;它通过将一个事务拆分为三个阶段来实现分布式事务的一致性。下面是一个使用Java语言实现TCC模式的简单案例&#xff1a; 定义业务操作接口&#xff1a…

Qt状态机框架

概述 状态机框架提供了用于创建和执行状态图的类。这些概念和符号基于Harel的Statecharts:复杂系统的可视化形式(http://www.wisdom.weizmann.ac.il/~dharel/SCANNED.PAPERS/Statecharts.pdf)&#xff0c;也是UML状态图的基础。状态机执行的语义基于状态图XML (SCXML)(http://…

Java基础知识巩固自测(上)

前言 该文章适用于已初步了解Java基础知识的入门学习者&#xff0c;便于快速回顾知识点&#xff0c;查漏补缺。 内容包括&#xff1a;Java面向对象相关知识、SQL基础语法 复习建议技巧 实用3W思维法&#xff08;What、Why、How&#xff09; 1. What&#xff08;什么&#x…

jEasyUI 树形菜单拖放控制

jEasyUI 树形菜单拖放控制 jEasyUI 是一个基于 jQuery 的框架&#xff0c;它为开发者提供了一套完整的用户界面组件。这些组件包括菜单、窗口、按钮、面板等&#xff0c;它们可以帮助开发者快速构建功能丰富且美观的网页应用程序。在本文中&#xff0c;我们将重点讨论如何使用…

mysql面试题 Day1

目录 1 可以使用mysql直接存储文件吗&#xff1f; 2 什么时候存文件&#xff0c;什么时候不存文件&#xff1f; 3 存储文件&#xff0c;有遇到什么问题吗&#xff1f; 4 emoji 乱码怎么办&#xff1f; 5 如何存储ip地址&#xff1f; 1 可以使用mysql直接存储文件吗&#xf…

Web的UI自动化基础知识

目录 1 Web自动化入门基础1.1 自动化知识以及工具1.2 主流web自动化测试工具1.3 入门案例 2 使用工具的API2.1 元素定位2.1.1 id选择器2.1.2 name2.1.3 class_name选择器2.1.4 tag_name选择器2.1.5 link_text选择器2.1.6 partial_link_text选择器2.1.7 xpath选择器2.1.8 CSS选择…