L1-095 分寝室(Java)

学校新建了宿舍楼,共有 n 间寝室。等待分配的学生中,有女生 n0 位、男生 n1 位。所有待分配的学生都必须分到一间寝室。所有的寝室都要分出去,最后不能有寝室留空。
现请你写程序完成寝室的自动分配。分配规则如下:

  • 男女生不能混住;
  • 不允许单人住一间寝室;
  • 对每种性别的学生,每间寝室入住的人数都必须相同;例如不能出现一部分寝室住 2 位女生,一部分寝室住 3 位女生的情况。但女生寝室都是 2 人一间,男生寝室都是 3 人一间,则是允许的;
  • 在有多种分配方案满足前面三项要求的情况下,要求两种性别每间寝室入住的人数差最小。

输入格式:

输入在一行中给出 3 个正整数 n0、n1、n,分别对应女生人数、男生人数、寝室数。数字间以空格分隔,均不超过 105。

输出格式:

在一行中顺序输出女生和男生被分配的寝室数量,其间以 1 个空格分隔。行首尾不得有多余空格。
如果有解,题目保证解是唯一的。如果无解,则在一行中输出 No Solution。

输入样例 1:

24 60 10

输出样例 1:

4 6

注意:输出的方案对应女生都是 24/4=6 人间、男生都是 60/6=10 人间,人数差为 4。满足前三项要求的分配方案还有两种,即女生 6 间(都是 4 人间)、男生 4 间(都是 15 人间);或女生 8 间(都是 3 人间)、男生 2 间(都是 30 人间)。但因为人数差都大于 4 而不被采用。

输入样例 2:

29 30 10

输出样例 2:

No Solution

解题思路

  1. 遍历所有可能的女生寝室数量(从1到n),对于每个可能的女生寝室数量,计算剩余的寝室数量分配给男生。
  2. 对于每种分配方案,检查是否满足以下条件:
    • 每间寝室的入住人数都是整数。
    • 女生和男生的寝室都没有剩余。
    • 两种性别每间寝室入住的人数差最小。
  1. 如果找到符合条件的分配方案,则输出该方案;如果没有找到任何符合条件的方案,则输出“No Solution”。

解题过程中遇到的问题

这是我最开始的思路,但是有个案例不通过。分析思路:

  1. 所有寝室都被分配且没有剩余:通过确保男女生人数都能被相应的寝室数量整除。
  2. 男女生不能混住:通过分别计算男生和女生的寝室数量。
  3. 不允许单人住一间寝室:需要确保每间寝室的入住人数都大于1。
  4. 每间寝室入住人数必须相同:通过确保整除来满足这一条件。
  5. 两种性别每间寝室入住的人数差最小:通过计算差值并找出最小差值来实现这一点。

错误代码:

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int n0 = scanner.nextInt(); // 女生人数
        int n1 = scanner.nextInt(); // 男生人数
        int n = scanner.nextInt();  // 寝室数

        int finalGirlsDorms = 0;
        int finalBoysDorms = 0;
        int minDiff = Integer.MAX_VALUE; // 初始化最小差异

        for (int girlsDorms = 1; girlsDorms < n; girlsDorms++) {
            int boysDorms = n - girlsDorms;
            if (n0 % girlsDorms == 0 && n1 % boysDorms == 0) {
                int girlsPerDorm = n0 / girlsDorms;
                int boysPerDorm = n1 / boysDorms;
                int diff = Math.abs(girlsPerDorm - boysPerDorm);

                if (diff < minDiff) {
                    minDiff = diff;
                    finalGirlsDorms = girlsDorms;
                    finalBoysDorms = boysDorms;
                }
            }
        }

        if (finalGirlsDorms == 0) {
            System.out.println("No Solution");
        } else {
            System.out.println(finalGirlsDorms + " " + finalBoysDorms);
        }

    }
}

代码

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int n0 = scanner.nextInt(); // 女生人数
        int n1 = scanner.nextInt(); // 男生人数
        int n = scanner.nextInt();  // 寝室数

        int finalGirlsDorms = 0;
        int finalBoysDorms = 0;
        int minDiff = Integer.MAX_VALUE; // 初始化最小差异

        for (int girlsDorms = 1; girlsDorms <= n; girlsDorms++) {
            int boysDorms = n - girlsDorms;
            if (girlsDorms != n && boysDorms != n && n0 % girlsDorms == 0 && n1 % boysDorms == 0) {
                int girlsPerDorm = n0 / girlsDorms;
                int boysPerDorm = n1 / boysDorms;
                //不允许单人住一间寝室
                if (girlsPerDorm > 1 && boysPerDorm > 1) {
                    int diff = Math.abs(girlsPerDorm - boysPerDorm);
                    if (diff < minDiff) {
                        minDiff = diff;
                        finalGirlsDorms = girlsDorms;
                        finalBoysDorms = boysDorms;
                    }
                }
            }
        }

        if (finalGirlsDorms == 0) {
            System.out.println("No Solution");
        } else {
            System.out.println(finalGirlsDorms + " " + finalBoysDorms);
        }
    }
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

AI对比:ChatGPT和文心一言的区别和差异

目录 一、ChatGPT和文心一言大模型的对比分析 1.1 二者训练的数据情况分析 1.2 训练大模型数据规模和参数对比 1.3 二者3.5版本大模型对比总结 二、ChatGPT和文心一言功能对比分析 2.1 二者产品提供的功能情况分析 2.2 测试一下各种功能的特性 2.2.1 文本创作能力 2.2…

分布式一致性算法---Raft初探

读Raft论文也有一段时间了&#xff0c;但是自己总是以目前并没有完全掌握为由拖着这篇博客。今天先以目前的理解程度&#xff08;做了6.824的lab2A和lab2B&#xff09;对这篇论文做一个初步总结&#xff0c;之后有了更深入的理解之后再进行迭代&#xff0c;关于本文有任何疑问欢…

【数据结构和算法】--- 二叉树(3)--二叉树链式结构的实现(1)

目录 一、二叉树的创建(伪)二、二叉树的遍历2.1 前序遍历2.2 中序遍历2.3 后序遍历 三、二叉树节点个数及高度3.1 二叉树节点个数3.2 二叉树叶子节点个数3.3二叉树第k层节点个数3.4 二叉树查找值为x的节点 四、二叉树的创建(真) 一、二叉树的创建(伪) 在学习二叉树的基本操作前…

vertica10.0.0单点安装_ubuntu18.04

ubuntu的软件包格式为deb&#xff0c;而rpm格式的包归属于红帽子Red Hat。 由于项目一直用的vertica-9.3.1-4.x86_64.RHEL6.rpm&#xff0c;未进行其他版本适配&#xff0c;而官网又下载不到vertica-9.3.1-4.x86_64.deb&#xff0c;尝试通过alian命令将rpm转成deb&#xff0c;但…

【GitHub项目推荐--Git 教程】【转载】

本开源项目是 Will 保哥在 2013 第 6 界 IT 邦帮忙铁人赛年度大奖的得奖著作。这是一个 Git 教程&#xff0c;这个开源教程用 30 天的时间&#xff0c;带领大家详细了解使用 Git 。 重点介绍了 Git 的一些常用操作&#xff0c;以及日常工作中实际应用场景讲解&#xff0c;下图…

让二叉树无处可逃

志不立&#xff0c;天下无可成之事。 ——王阳明 二叉树 1、树&#xff1f;什么是树1、1、基本概念1、2、树的相关概念1、3、树的表示方式1、4、树的实际运用 2、二叉树&#xff1f;只有两个分支吗&#xff1f;2、1、基本概念2、2、二叉树的相关定义2、3、二叉树的相关性质2、4…

Dockerfile-xxxx

1、Dockerfile-server FROM openjdk:8-jdk-alpine WORKDIR /app COPY . . CMD java -Xms1536M -Xmx1536M -XX:UseG1GC -jar -Dlog4j2.formatMsgNoLookupstrue -Dloader.pathresources,lib -Duser.timezoneGMT-05 /app/server-main-1.0.0.jar 2、Dockerfile-bgd #FROM openjdk…

一站式社交媒体管理:揭秘HubSpot的全面解决方案

在当今数字化时代&#xff0c;社交媒体已经成为企业推广和品牌塑造的关键渠道。而HubSpot作为一站式市场营销平台&#xff0c;不仅致力于协助企业实现综合市场目标&#xff0c;更在社交媒体管理领域提供了全面解决方案。今天运营坛将深入探讨HubSpot如何成为一站式社交媒体管理…

DAY08_SpringBoot—整合Mybatis-Plus

目录 1 MybatisPlus1.1 MP介绍1.2 MP的特点1.3 MybatisPlus入门案例1.3.1 导入jar包1.3.2 编辑POJO对象1.3.3 编辑Mapper接口1.3.4 编译YML配置文件1.3.5 编辑测试案例 1.4 MP核心原理1.4.1 需求1.4.2 原理说明1.4.3 对象转化Sql原理 1.5 MP常规操作1.5.1 添加日志打印1.5.2 测…

哪个牌子的洗地机质量好?值得入手的洗地机

在家庭清洁方面&#xff0c;洗地机绝不是被认为的智商税。实际上&#xff0c;洗地机是一种非常实用的清洁工具&#xff0c;其最大的优点在于能够高效地协助我们清理家居环境&#xff0c;不论是在何种场景下&#xff0c;都能有效提升卫生水平。然而&#xff0c;由于市场上存在众…

seata1.8 + nacos,store.mode=db

吐槽一下&#xff0c;官方文档是真少&#xff0c;而且更新很不及时。。 官网地址&#xff1a;直接部署 | Apache Seata 上述地址也包含了下载链接&#xff0c;我用的1.8版本&#xff0c;挑一些关键配置说一下 1、服务器上&#xff0c;seata/conf/application.yml&#xff0c;将…

【数据结构】从顺序表到ArrayList类

文章目录 1.线性表1.1线性表的概念2.顺序表2.1顺序表的概念2.2顺序表的实现2.3接口的实现(对数组增删查改操作)3.ArrayList简介4. ArrayList使用 4.1ArrayList的构造4.2 ArrayList的方法4.3 ArrayList的遍历 1.线性表 1.1线性表的概念 线性表&#xff08;linear list&#xf…

HCIP-10

交换机的作用&#xff1a; 区别集线器&#xff08;HUB&#xff09;&#xff0c;HUB为物理层设备&#xff0c;只能直接转发发电流&#xff1b; 交换机为数据链路层设备&#xff0c;可以将电流与二进制转换&#xff0c;实现了以下功能&#xff1a; 无限的传输距离彻底解决了冲突…

条件概率、全概率和贝叶斯公式

目录 1. 条件概率 1.1 条件概率说明 1.2 举例说明 1.3 条件概率公式 2. 全概率公式 2.1 条件概率公式 2.2 一个特例公式 2.3 全概率公式的意义 3. 贝叶斯公式 3.1 贝叶斯公式的推导 3.2 贝叶斯公式一个特例 ​​​​​​​3.3 贝叶斯公式的意义 4. 先验概率 &…

6.1 实现微服务:匹配系统(上中下)

WebSocketConfig。ja&#xff08;onOpen建立连接时自动调用onClose关闭链接时自动调用&#xff08;user还存在就在线程移除&#xff09;onMessageServer从Client接收消息时触发&#xff09; status&#xff1a;match来切换界面是不是匹配还是比赛的 解析token&#xff0c;如果…

Elastic Observability 8.12:AI 助手、SLO 和移动 APM 支持的正式发布

作者&#xff1a;来自 Elastic Tom Grabowski, Akhilesh Pokhariyal Elastic Observability 8.12 宣布 AI Assistant 全面上市 (正式发布)、服务级别目标 (SLO) 和移动 APM 支持&#xff1a; 服务级别目标 (service level objective - SLO)&#xff1a;现在正式发布版允许 SRE…

python:socket基础操作(2)-《udp发送信息》

基础发送udp信息 1.导入socket模块 2.使用udp模块 3.发送内容 4.关闭套接字 很简单的4步就可以实现udp的消息发送 import socket # 导入模块udp_socket socket.socket(socket.AF_INET,socket.SOCK_DGRAM) # 使用ipv4 udp协议udp_socket.sendto(b"hello world",(&…

即插即用篇 | UniRepLKNet:用于音频、视频、点云、时间序列和图像识别的通用感知大卷积神经网络 | DRepConv

大卷积神经网络(ConvNets)近来受到了广泛研究关注,但存在两个未解决且需要进一步研究的关键问题。1)现有大卷积神经网络的架构主要遵循传统ConvNets或变压器的设计原则,而针对大卷积神经网络的架构设计仍未得到解决。2)随着变压器在多个领域的主导地位,有待研究ConvNets…

精品基于Uniapp+springboot智慧校园管理系统App课程选课成绩

《[含文档PPT源码等]精品基于Uniappspringboot智慧校园管理系统App》该项目含有源码、文档、PPT、配套开发软件、软件安装教程、项目发布教程、包运行成功&#xff01; 软件开发环境及开发工具&#xff1a; 开发语言&#xff1a;Java 后台框架&#xff1a;springboot、ssm …

ffmpeg使用及java操作

1.文档 官网: FFmpeg 官方使用文档: ffmpeg Documentation 中文简介: https://www.cnblogs.com/leisure_chn/p/10297002.html 函数及时间: ffmpeg日记1011-过滤器-语法高阶&#xff0c;逻辑&#xff0c;函数使用_ffmpeg gte(t,2)-CSDN博客 java集成ffmpeg: SpringBoot集成f…