二进制二维数组与装箱问题

装箱问题(Bin Packing Problem)是一类经典的优化问题,其目标是将一系列项目(通常具有不同的体积或重量)分配到尽量少的箱子中,使得每个箱子的容量不被超出。这种问题在物流、资源分配、内存管理等领域有广泛应用。

对于一个二进制二维数组,装箱问题可以视为如何将多个矩形子块(即一组1的集合)紧凑地放入有限大小的容器中。这种问题也称为二维装箱问题(2D Bin Packing Problem)。

在这里插入图片描述

1、问题背景

给定一个二进制二维数组 bin,其中 0 表示空位置,1 表示已占用的位置。还需要一个包含整数的列表 block,其中每个整数表示一个正方形块的边长。

目标是将这些块放入 bin 中,使得每个块都不与其他块或 bin 的边界重叠。同时,还需计算出在将所有块放入 bin 之后,剩余的空位置数量。

2、解决方案

为了解决这个问题,可以使用以下步骤:

  1. 使用 isSpaceFree 函数检查 bin 中是否有足够的空间来放置指定大小的块。
  2. 如果有足够的空间,则使用 packing 函数将块放入 bin 中。
  3. 重复步骤 1 和 2,直到将所有块都放入 bin 中或没有更多空间来放置块。
  4. 计算 bin 中剩余的空位置数量。

以下是在 Python 中实现上述算法的代码示例:

def isSpaceFree(bin, row, column, block):
    """检查 `bin` 中是否有足够的空间来放置指定大小的块。

    Args:
        bin: 二进制二维数组。
        row: 块的起始行号。
        column: 块的起始列号。
        block: 块的边长。

    Returns:
        如果 `bin` 中有足够的空间来放置块,则返回 `True`;否则,返回 `False`。
    """

    if row + block > len(bin):
        return False
    if column + block > len(bin[0]):
        return False
    else:
        return False

    for r in range(row, row + block):
        for c in range(column, column + block):
            if bin[r][c] != 0:
                return False
    return True


def packing(bin, row, column, block):
    """将块放入 `bin` 中。

    Args:
        bin: 二进制二维数组。
        row: 块的起始行号。
        column: 块的起始列号。
        block: 块的边长。

    Returns:
        无。
    """

    if isSpaceFree(bin, row, column, block):
        for r in range(row, row + block):
            for c in range(column, column + block):
                bin[r][c] = block


def main():
    """程序的主函数。

    Args:
        无。

    Returns:
        无。
    """

    # 读取输入数据。
    bin_size = int(input("请输入 `bin` 的大小:"))
    block_list = [int(x) for x in input("请输入块的大小列表,以空格分隔:").split()]

    # 创建一个 `bin` 二维数组。
    bin = [[0 for _ in range(bin_size)] for _ in range(bin_size)]

    # 将块放入 `bin` 中。
    for block in block_list:
        for row in range(bin_size):
            for column in range(bin_size):
                if isSpaceFree(bin, row, column, block):
                    packing(bin, row, column, block)
                    break

    # 计算 `bin` 中剩余的空位置数量。
    empty_spaces = 0
    for row in range(bin_size):
        for column in range(bin_size):
            if bin[row][column] == 0:
                empty_spaces += 1

    # 打印结果。
    print("剩余的空位置数量:", empty_spaces)


if __name__ == "__main__":
    main()

在上面的代码中,main 函数首先读取输入数据,包括 bin 的大小和块的大小列表。然后,它创建一个 bin 二维数组。接下来,它遍历块的大小列表,并尝试将每个块放入 bin 中。如果找到一个足够的空间来放置块,则将块放入 bin 中,并继续尝试将下一个块放入 bin 中。如果找不到足够的空间来放置块,则跳过该块。最后,main 函数计算 bin 中剩余的空位置数量,并打印结果。

上述代码是一个非常基础的实现,实际应用中可以考虑更复杂的启发式方法或动态规划方法来提高算法的效率和解的质量。对于更大规模的问题,可以考虑并行计算或使用专门的优化库。

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

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

相关文章

LinkedList----源码分析

源码介绍 public class LinkedList<E>extends AbstractSequentialList<E>implements List<E>, Deque<E>, Cloneable, java.io.Serializable{} 添加过程中的操作&#xff1a; 当创建LinkedList类时&#xff0c;会调用其空参构造方法&#xff0c;将其参…

第一关:Linux基础知识

Linux基础知识目录 前言LinuxInternStudio 关卡1. InternStudio开发机介绍2. SSH及端口映射2.1 什么是SSH&#xff1f;2.2 如何使用SSH远程连接开发机&#xff1f;2.2.1 使用密码进行SSH远程连接2.2.2 配置SSH密钥进行SSH远程连接2.2.3 使用VScode进行SSH远程连接 2.3. 端口映射…

6-5,web3浏览器链接区块链(react+区块链实战)

6-5&#xff0c;web3浏览器链接区块链&#xff08;react区块链实战&#xff09; 6-5 web3浏览器链接区块链&#xff08;调用读写合约与metamask联动&#xff09; 6-5 web3浏览器链接区块链&#xff08;调用读写合约与metamask联动&#xff09; 这里就是浏览器端和智能合约的交…

论文阅读【时空+大模型】ST-LLM(MDM2024)

论文阅读【时空大模型】ST-LLM&#xff08;MDM2024&#xff09; 论文链接&#xff1a;Spatial-Temporal Large Language Model for Traffic Prediction 代码仓库&#xff1a;https://github.com/ChenxiLiu-HNU/ST-LLM 发表于MDM2024&#xff08;Mobile Data Management&#xf…

回归损失和分类损失

回归损失和分类损失是机器学习模型训练过程中常用的两类损失函数&#xff0c;分别适用于回归任务和分类任务。 回归损失函数 回归任务的目标是预测一个连续值&#xff0c;因此回归损失函数衡量预测值与真实值之间的差异。常见的回归损失函数有&#xff1a; 均方误差&#xff…

srs直播内网拉流带宽飙升问题记录

问题背景 srs部署在云服务器上&#xff0c;32核cpu&#xff0c;64G内存&#xff0c;带宽300M. 客户端从srs拉流&#xff0c;发现外网客户端拉流&#xff0c;cpu和带宽都正常。然而内网客户端拉流&#xff0c;拉流人数超过5人以上&#xff0c;带宽就会迅速飙升。 排查 用srs…

Pandas数学函数大揭秘:让数据处理变得如此简单高效,轻松玩转数据分析新纪元!

1.导包 # 导包 import numpy as np import pandas as pd2.聚合函数 df pd.DataFrame(datanp.random.randint(0,100,size(5,3))) df01203550281552376231419335895434679917 # 列非空元素的数量 df.count()0 5 1 5 2 5 dtype: int64# 行非空元素的数量 df.count(ax…

小白的OS Copilot 产品测评

背景 通过群友介绍才知OS Copilot 。不想错过任何优秀的AI产品。随着互联网的发展和时代的进步&#xff0c;要紧跟时代&#xff0c;了解市面上的优秀的AI科技产品。 OS Copilot 产品体验评测 1&#xff09;您的角色是什么&#xff1f;开发、运维、学生&#xff1f;如果使用O…

7.11日学习打卡----初学Redis(六)

7.11日学习打卡 目录&#xff1a; 7.11日学习打卡一. redis事务事务的概念与ACID特性Redis事务三大特性Redis事务执行的三个阶段Redis事务基本操作 二. redis集群主从复制主从复制环境搭建主从复制原理剖析 哨兵监控哨兵监控环境搭建哨兵工作原理剖析 故障转移Cluster模式Clust…

MES系统是如何进行工艺管理的

1. MES系统工艺管理 工艺管理是MES制造执行系统中至关重要的功能模块之一&#xff0c;它涉及到产品从设计到生产的整个工艺流程的规划、执行和优化。以下是对MES系统中工艺管理模块的详细介绍&#xff1a; 1.1 工艺流程设计 工艺流程设计是MES系统工艺管理的核心部分&#xf…

PCI PTS 硬件安全模块(HSM)模块化安全要求 v5.0

符合条件的 PCI SSC 利益相关者在 30 天的意见征询 (RFC) 期间审查 PCI PTS 硬件安全模块 (HSM) 模块化安全要求 v5.0 草案并提供反馈。 PCI PTS 硬件安全模块(HSM)模块化安全要求 v5.0图 从 7 月 8 日到 8 月 8 日&#xff0c;邀请符合条件的 PCI SSC 利益相关者在 30 天的意见…

使用getopt处理参数

文章目录 使用getopt处理参数1. shift 命令1.1 删除一个参数1.2 删除多个参数1.3 多次执行 shift 参数1.4 参数解析示例1.5 优化处理1.6 问题处理 2. getopt 命令2.1 常用参数及示例2.2 脚本参数优化示例2.3 参数校验 3. 示例展示4. eval 命令4.1 示例示例 1示例 2示例 3示例 4…

“论软件维护方法及其应用”写作框架,软考高级论文,系统架构设计师论文

论文真题 软件维护是指在软件交付使用后&#xff0c;直至软件被淘汰的整个时间范围内&#xff0c;为了改正错误或满足 新的需求而修改软件的活动。在软件系统运行过程中&#xff0c;软件需要维护的原因是多种多样的&#xff0c; 根据维护的原因不同&#xff0c;可以将软件维护…

新火种AI|微软和苹果放弃OpenAI董事会观察员席位

作者&#xff1a;一号 编辑&#xff1a;美美 微软苹果双双不做OpenAI“观察员”&#xff0c;OpenAI能更自由吗&#xff1f; 7月10消息&#xff0c;微软当地时间周一宣布将放弃在OpenAI董事会的观察员席位&#xff0c;他们称&#xff0c;OpenAI在过去八个月中取得了“重大进展…

天润融通引领客服革新,AI大模型助力品牌服务升级

AI时代&#xff0c;消费零售品牌的客户服务应该怎么做&#xff1f; 如今消费者的关注点已经越来越复杂&#xff0c;一条毛巾&#xff0c;关注点就可以包括&#xff1a; 是否婴幼儿可用&#xff0c;是否儿童成人可用&#xff1b;是否可以直接接触皮肤&#xff1b;是否无甲醛、…

初学SpringMVC之接收请求参数及数据回显

pom.xml 文件导入 lombok 的依赖 <dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.34</version></dependency> Controller 表示这是一个控制器 RequestParam 表示从前端接收…

14 - matlab m_map地学绘图工具基础函数 - 一些数据转换函数(一)

14 - matlab m_map地学绘图工具基础函数 - 一些数据转换函数&#xff08;一&#xff09; 0. 引言1. 关于m_ll2xy和m_xy2ll2. 关于m_lldist3. 关于m_xydist4 关于m_fdist5 关于m_idist6. 总结 0. 引言 通过前面篇节已经将m_map绘图工具中大多绘图有关的函数进行过介绍&#xff0…

axios使用sm2加密数据后请求参数多了双引号解决方法

axios使用sm2加密数据后请求参数多了双引号解决 背景问题描述解决过程 背景 因项目安全要求&#xff0c;需对传给后端的入参加密&#xff0c;将请求参数加密后再传给后端 前期将axios降低到1.6.7后解决了问题&#xff0c;但最近axios有漏洞&#xff0c;安全要求对版本升级&…

three完全开源扩展案例02-跳动的音乐

更多案例尽在https://threelab.cn/ 演示地址 import * as THREE from "three"; import { OrbitControls } from "three/examples/jsm/controls/OrbitControls.js";let mediaElement; let analyser; let scene; let camera; let renderer; let controls; …

应力 (Stress) 是指单位面积上所承受的力

应力 (Stress) 是指单位面积上所承受的力 flyfish 轴向力 轴向力 (Axial Force) 是指沿着物体的纵轴施加的力。对于一根杆或柱子&#xff0c;轴向力可以是拉力或压力&#xff0c;具体取决于力的方向。 拉力 (Tensile Force)&#xff1a;使物体拉长的力。 压力 (Compressive…