基于OR-Tools的装箱问题模型求解(PythonAPI)

news2024/11/24 17:30:17

装箱问题

  • 一、背包问题(Knapsack problem)
    • 1.1 0-1背包模型
      • 基于OR-Tools的0-1背包问题求解(PythonAPI)
        • 导入pywraplp库
        • 数据准备
        • 声明MIP求解器
        • 初始化决策变量
        • 初始化约束条件
        • 目标函数
        • 调用求解器
        • 打印结果
    • 1.2 多重背包问题(Multiple knapsack problems)
      • 基于OR-Tools多重背包问题求解(PythonAPI)
    • 1.3 多维背包问题(Multi-dimensional knapsack problems)
      • 基于OR-Tools多维背包问题求解(PythonAPI)
  • 二、装箱问题(Bin-packing problem)
      • 基于OR-Tools的装箱问题求解(PythonAPI)

装箱问题(packing problem)的描述是要将一组给定尺寸的物品放置到具有固定容量的容器中,一般情况下由于容器有容量限制,不可能放入所有物品,那么装箱问题的目标是要找到限定约束下使得总价值最大或总花费最小的装箱方法。根据我们具体的目标情况,装箱问题又可分为两类:

  • 背包问题(Knapsack problem),容器数量是固定的,每个容器有自己的最大容量,而需要分配的物件有各自的价值,我们的目标是让装入容器的物体的总价值最大,并不要求所有物体都装入;
  • 装箱问题( Bin-packing problem),容器容量是相同的,但是数量不固定,我们的目标是用最少的容器来存放所有的物件。
    在这里插入图片描述

一、背包问题(Knapsack problem)

旅行者要在一个背包内装入一些对旅行最有用得物品(旅行者对每件物品的价值都有评判)。背包最多只能装入总重为b单位的物品,并且对于每件物品只能选择整个携带或者不携带。假设共有n件物品,第 j j j件物品重 a j a_j aj单位,其价值为 c j c_j cj。在携带物品总重量不超过 b b b单位的条件下,请问如何装入物品以使背包内的物品价值最大?

1.1 0-1背包模型

对于 j = 1 , . . . , n j=1,...,n j=1,...,n,定义0-1决策变量 x j = 1 x_j=1 xj=1表示携带物品 j j j。则物品的数学模型为:
max ⁡ ∑ j ∈ J c j x j subject to ∑ j = 1 n a j x j ≤ b , x j ∈ { 0 , 1 } , ∀ j = 1 , . . . , n \begin{align} \max \quad &\sum_{j \in J} c_{j}x_{j} \\ \text{subject to} \quad &\sum_{j=1}^n a_{j}x_{j} \leq b, \\ &x_{j} \in \{0,1\}, \quad \forall j=1,...,n \end{align} maxsubject tojJcjxjj=1najxjb,xj{0,1},j=1,...,n
具有上述形式的整数规划模型称为背包模型,其中约束条件(2)称为背包约束,约束条件(3)定义了0-1变量 x j x_j xj

基于OR-Tools的0-1背包问题求解(PythonAPI)

OR-Tools官网题目
50个物品被装入一个箱子。每个物品都有一个值(物品上的数字)和一个重量(与物品的面积大致成比例)。背包的容量被为850,目标是找到一组能使总价值最大化而又不超过容量的物品。

导入pywraplp库
from ortools.linear_solver import pywraplp
数据准备
values = [
    360, 83, 59, 130, 431, 67, 230, 52, 93, 125, 670, 892, 600, 38, 48, 147,
    78, 256, 63, 17, 120, 164, 432, 35, 92, 110, 22, 42, 50, 323, 514, 28,
    87, 73, 78, 15, 26, 78, 210, 36, 85, 189, 274, 43, 33, 10, 19, 389, 276,
    312
]
weights = [
    7, 0, 30, 22, 80, 94, 11, 81, 70, 64, 59, 18, 0, 36, 3, 8, 15, 42, 9, 0,
    42, 47, 52, 32, 26, 48, 55, 6, 29, 84, 2, 4, 18, 56, 7, 29, 93, 44, 71,
    3, 86, 66, 31, 65, 0, 79, 20, 65, 52, 13
]
capacities = 850         # 背包容量
num_items = len(weights) # 物品数量
声明MIP求解器
solver = pywraplp.Solver.CreateSolver("SCIP")
初始化决策变量
x = {}
for j in range(num_items):
    x[j] = solver.IntVar(0, 1, f"x{j}")
print(x)
{0: x0, 1: x1, 2: x2, 3: x3, 4: x4, 5: x5, 6: x6, 7: x7, 8: x8, 9: x9, 10: x10, 11: x11, 12: x12, 13: x13, 14: x14, 15: x15, 16: x16, 17: x17, 18: x18, 19: x19, 20: x20, 21: x21, 22: x22, 23: x23, 24: x24, 25: x25, 26: x26, 27: x27, 28: x28, 29: x29, 30: x30, 31: x31, 32: x32, 33: x33, 34: x34, 35: x35, 36: x36, 37: x37, 38: x38, 39: x39, 40: x40, 41: x41, 42: x42, 43: x43, 44: x44, 45: x45, 46: x46, 47: x47, 48: x48, 49: x49}
初始化约束条件
solver.Add(solver.Sum([weights[j] * x[j] for j in range(num_items)]) <= capacities)
<ortools.linear_solver.pywraplp.Constraint; proxy of <Swig Object of type 'operations_research::MPConstraint *' at 0x0000017B2B458510> >

上面这种写法将列表推导式打开,等价于:

cn_terms = []
for j in range(num_items):
    cn_terms.append(weights[j] * x[j])
solver.Add(solver.Sum(cn_terms))

还有另外一种写法:

constraint = solver.RowConstraint(0, capacities, "")
for j in range(num_items):
    constraint.SetCoefficient(x[j], weights[j])
目标函数
objective_terms = []
for j in range(num_items):
    objective_terms.append(values[j] * x[j])
solver.Maximize(solver.Sum(objective_terms))
调用求解器
status = solver.Solve()
打印结果
if status == pywraplp.Solver.OPTIMAL or status == pywraplp.Solver.FEASIBLE:
    print(f"Total cost = {solver.Objective().Value()}")
    total_weight = 0
    picked_items = []
    for j in range(num_items):
        # Test if x[i,j] is 1 (with tolerance for floating point arithmetic).
        if x[j].solution_value() > 0.5:
            total_weight += weights[j]
            picked_items.append(j)
    print(f"total weight={total_weight}")
    print(f"装入了背包的物品:{picked_items}")

else:
    print("No solution found.")
Total cost = 7534.0
total weight=850
装入了背包的物品:[0, 1, 3, 4, 6, 10, 11, 12, 14, 15, 16, 17, 18, 19, 21, 22, 24, 27, 28, 29, 30, 31, 32, 34, 38, 39, 41, 42, 44, 47, 48, 49]

1.2 多重背包问题(Multiple knapsack problems)

把单个背包扩展到多个背包,就是多背包问题,对于多背包问题,我们可以采用下面的定义方式:
给出n个物件(j=1,…,n)和m个背包(i=1,…,m)(m ≤ n ),0-1决策变量x_ij =1将物品 j 装入背包 i 。按如下定义(仍然只是单维):
max ⁡ ∑ i ∈ I ∑ j ∈ J c j x i j subject to ∑ j = 1 n a j x i j ≤ b i , ∀ i = 1 , . . . , m ∑ i ∈ I x i j ≤ 1 , ∀ j = 1 , . . . , n x j ∈ { 0 , 1 } , ∀ j = 1 , . . . , n \begin{align} \max \quad & \sum_{i \in I}{}\sum_{j \in J} c_{j}x_{ij}\\ \text{subject to} \quad &\sum_{j=1}^n a_{j}x_{ij} \leq b_i, \quad \forall i =1,...,m \\ &\sum_{i \in I}{x_{ij}} \leq1,\quad \forall j =1,...,n \\ &x_{j} \in \{0,1\}, \quad \forall j=1,...,n \end{align} maxsubject toiIjJcjxijj=1najxijbi,i=1,...,miIxij1,j=1,...,nxj{0,1},j=1,...,n

基于OR-Tools多重背包问题求解(PythonAPI)

# The problem is to pack a subset of the items into five bins, each of which has a maximum capacity of 100, so that the total packed value is a maximum.
# 导入pywraplp库
from ortools.linear_solver import pywraplp

weights = [48, 30, 42, 36, 36, 48, 42, 42, 36, 24, 30, 30, 42, 36, 36]
values = [10, 30, 25, 50, 35, 30, 15, 40, 30, 35, 45, 10, 20, 30, 25]
knapsack_capacities = [100, 100, 100, 100, 100]  # 5个背包的容量

num_items = len(weights)  # 物品数量
num_knapsacks = len(knapsack_capacities)  # 5个背包

# 声明MIP求解器
solver = pywraplp.Solver.CreateSolver("SCIP")

# 初始化决策变量
x = {}
for i in range(num_knapsacks):
    for j in range(num_items):
        x[i, j] = solver.IntVar(0, 1, f'x{i}{j}')

# 背包约束
for i in range(num_knapsacks):
    cn_terms = []
    for j in range(num_items):
        cn_terms.append(weights[j] * x[i, j])
    solver.Add(solver.Sum(cn_terms) <= knapsack_capacities[i])

# 约束:每个物品只能装入一个背包
for j in range(num_items):
    cn_terms = []
    for i in range(num_knapsacks):
        cn_terms.append(x[i, j])
    solver.Add(solver.Sum(cn_terms) <= 1)
# 目标函数
objective_terms = []
for i in range(num_knapsacks):
    for j in range(num_items):
        objective_terms.append(values[j] * x[i, j])
solver.Maximize(solver.Sum(objective_terms))
# 调用求解器
status = solver.Solve()
# 打印结果
if status == pywraplp.Solver.OPTIMAL or status == pywraplp.Solver.FEASIBLE:
    print(f"Total cost = {solver.Objective().Value()}\n")
    knapsack = {}
    for i in range(num_knapsacks):
        knapsack[i] = []
        for j in range(num_items):
            if x[i, j].solution_value() > .5:
                knapsack[i].append(j)
    print("背包—放入的物品:", knapsack)

1.3 多维背包问题(Multi-dimensional knapsack problems)

实际生活中可能限制背包存放物体数量的不仅是重量,还有体积等属性,因此上面的定义更严格的来说应该是单维单背包问题,如果有多维限定,那么在每一维存放物体的总量都不能超过背包的限定值。

max ⁡ ∑ i ∈ I ∑ j ∈ J c j x j subject to ∑ j = 1 n a i j x j ≤ b i , ∀ i = 1 , . . . , m x j ∈ { 0 , 1 } , ∀ j = 1 , . . . , n \begin{align} \max \quad & \sum_{i \in I}{}\sum_{j \in J} c_{j}x_{j}\\ \text{subject to} \quad &\sum_{j=1}^n a_{ij}x_{j} \leq b_i, \quad \forall i =1,...,m \\ &x_{j} \in \{0,1\}, \quad \forall j=1,...,n \end{align} maxsubject toiIjJcjxjj=1naijxjbi,i=1,...,mxj{0,1},j=1,...,n

  • 决策变量 x j = 1 x_j=1 xj=1代表物品 j j j装入背包;
  • c i c_i ci:物品 i i i的价值;
  • n:物品的个数;
  • b i b_i bi维度 i i i的背包约束,如重量、体积等;
  • a i j a_{ij} aij表示物品 j j j对背包的约束 i i i的消耗;

基于OR-Tools多维背包问题求解(PythonAPI)

import pandas as pd
import numpy as np

# ==========测试==========
knapsack = {"weight": 600, "volume": 600}
values = [1898, 440, 22507, 270, 14148, 3100, 4650, 30800, 615, 4975, 1160, 4225, 510, 11880, 479, 440, 490, 330, 110,
          560, 24355, 2885, 11748, 4550, 750, 3720, 1950, 10500]

weights = [45, 5, 85, 150, 65, 95, 30, 12, 170, 20, 40, 25, 20, 3, 7, 25, 12, 22, 25, 9, 165, 2, 85, 15, 9, 2, 4, 100]
volumes = [30, 20, 125, 5, 80, 25, 35, 73, 12, 15, 15, 40, 5, 10, 10, 12, 10, 9, 10, 20, 60, 40, 50, 36, 49, 40, 19,
           150]
dimension_items = {
    "weight": weights,
    "volume": volumes
}
from ortools.linear_solver import pywraplp

solver = pywraplp.Solver.CreateSolver("SCIP")

num_dimensions = len(dimension_items)
num_items = len(values)
# 0-1决策变量
x = {}
for j in range(num_items):
    x[j] = solver.IntVar(0, 1, f'x{j}')

# 约束
for i in dimension_items.keys():
    cn_terms = []
    for j in range(num_items):
        cn_terms.append(dimension_items[i][j] * x[j])
    solver.Add(solver.Sum(cn_terms) <= knapsack[i])

# 目标函数
obj_terms = []
for j in range(num_items):
    obj_terms.append(values[j] * x[j])
solver.Maximize(solver.Sum(obj_terms))

status = solver.Solve()

if status == pywraplp.Solver.OPTIMAL or status == pywraplp.Solver.FEASIBLE:
    print(f"Total cost = {solver.Objective().Value()}\n")
    knapsack = []
    for j in range(num_items):
        if x[j].solution_value() > .5:
            knapsack.append(j)
    print("背包—放入的物品:", knapsack)

二、装箱问题(Bin-packing problem)

和背包问题不同,装箱问题问题是站在容器优化的角度来定义的,不再考虑放置物品的价值,而是希望用最少的容器装下所有的物品,每个容器的容量相同。装箱问题问题相比背包问题更加一般化,生活中物流等领域也常会遇到这种问题,比如用最少的运输车辆递送快递以最小化成本。

Bin packing problem: Given as many bins with a common capacity as necessary, find the fewest that will hold all the items. In this problem, the items aren’t assigned values, because the objective doesn’t involve value.

装箱问题问题也可以用整数规划模型来表示:
https://blog.csdn.net/wangzhenyang2/article/details/104595159

min ⁡ ∑ i m y i subject to ∑ j = 1 n a j x i j ≤ b ⋅ y i , ∀ i = 1 , . . . , m ∑ i = 1 m x i j = 1 , ∀ j = 1 , . . . , m x j ∈ { 0 , 1 } , ∀ j = 1 , . . . , n y i ∈ { 0 , 1 } , ∀ i = 1 , . . . , m \begin{align} \min \quad & \sum_{i}^m{} y_i\\ \text{subject to} \quad &\sum_{j=1}^n a_{j}x_{ij} \leq b \cdot y_i, \quad \forall i =1,...,m \\ &\sum_{i=1}^m x_{ij} = 1, \quad \forall j =1,...,m \\ &x_{j} \in \{0,1\}, \quad \forall j=1,...,n\\ &y_{i} \in \{0,1\}, \quad \forall i=1,...,m \end{align} minsubject toimyij=1najxijbyi,i=1,...,mi=1mxij=1,j=1,...,mxj{0,1},j=1,...,nyi{0,1},i=1,...,m

  • 决策变量 x i j = 1 x_{ij}=1 xij=1代表物品 j j j装入箱子 i i i
  • 决策变量 y i = 1 y_{i}=1 yi=1代表箱子 i i i被使用;
  • c i c_i ci:物品 i i i的价值;
  • n n n:物品的个数;
  • m m m:箱子个数;
  • b i b_i bi维度 i i i的背包约束;
  • a j a_{j} aj表示物品 j j j的重量;

基于OR-Tools的装箱问题求解(PythonAPI)

在这个例子中,不同重量的物品需要装入到一组容量相同的箱子中。假设有足够的箱子可以装下所有的物品,目标为使用的箱子数量最小。

from ortools.linear_solver import pywraplp

weights = [48, 30, 19, 36, 36, 27, 42, 42, 36, 24, 30]  # a
num_items = len(weights)  # n
num_bins = num_items  # m
bin_capacity = 100  # b

solver = pywraplp.Solver.CreateSolver("SCIP")

# 初始化决策变量
# Variables
# x[i, j] = 1 if item i is packed in bin j.
x = {}
for i in range(num_bins):
    for j in range(num_items):
        x[(i, j)] = solver.IntVar(0, 1, "x_%i_%i" % (i, j))

# y[j] = 1 if bin j is used.
y = {}
for i in range(num_bins):
    y[i] = solver.IntVar(0, 1, "y[%i]" % i)

# 约束条件
for i in range(num_bins):
    cn_terms = []
    for j in range(num_items):
        cn_terms.append(weights[j] * x[i, j])
    solver.Add(solver.Sum(cn_terms) <= bin_capacity * y[i])

for j in range(num_items):
    cn_terms = []
    for i in range(num_bins):
        cn_terms.append(x[i, j])
    solver.Add(solver.Sum(cn_terms) == 1)

# 目标函数
obj_terms = []
for i in range(num_bins):
    obj_terms.append(y[i])
solver.Minimize(solver.Sum(obj_terms))

status = solver.Solve()

if status == pywraplp.Solver.OPTIMAL or status == pywraplp.Solver.FEASIBLE:
    print(f"num of bins = {solver.Objective().Value()}\n")

    for i in range(num_bins):
        bin = []
        if y[i].solution_value() == 1:
            for j in range(num_items):
                if x[i, j].solution_value() > .5:
                    bin.append(j)
            print(f'箱子{i}-装入物品:{bin}')
else:
    print("No solution found.")
num of bins = 4.0

箱子0-装入物品:[0, 1, 2]
箱子1-装入物品:[3, 4, 5]
箱子2-装入物品:[6, 7]
箱子3-装入物品:[8, 9, 10]

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

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

相关文章

74X138元件怎么找——错误解决方法

1.在做74X138的时候根据课本&#xff0c;无法在现有的库中找到74X138&#xff0c;搜索了老师发的库中&#xff0c;都是集成库打不开&#xff0c;那我该怎么办? 根据这个课本P343&#xff0c;&#xff08;即机械工业出版社&#xff0c;刘超&#xff0c;包建荣&#xff0c;俞优姝…

深入理解TCP协议

深入理解TCP 1.TCP基础概念了解 1.1简介 TCP&#xff08;Transmission Control Protocol&#xff09;是一种计算机网络协议&#xff0c;用于在网络上可靠地传输数据。它确保数据的完整性、顺序性和可靠性&#xff0c;通过建立连接、数据分段、错误检测和恢复机制&#xff0c…

什么是DNS

什么是DNS 概述 域名系统&#xff08;英语&#xff1a;Domain Name System&#xff0c;缩写&#xff1a;DNS&#xff09;是互联网的一项服务。它作为将域名和IP地址相互映射的一个分布式数据库&#xff0c;能够使人更方便地访问互联网**。DNS使用[TCP和UDP端口53。当前&#…

【算法练习Day36】最后一块石头的重量 II目标和一和零

​&#x1f4dd;个人主页&#xff1a;Sherry的成长之路 &#x1f3e0;学习社区&#xff1a;Sherry的成长之路&#xff08;个人社区&#xff09; &#x1f4d6;专栏链接&#xff1a;练题 &#x1f3af;长路漫漫浩浩&#xff0c;万事皆有期待 文章目录 最后一块石头的重量 II目标…

2m照片用手机怎么照?三个方法随心选!

在用手机拍照的时候&#xff0c;我们会发现拍出的照片尺寸都很大&#xff0c;占用手机的存储空间较多&#xff0c;而自己又不需要如此高清晰度的照片&#xff0c;那么如何解决这个问题呢&#xff1f;下面介绍了三种方法。 方法一&#xff1a;调整手机拍照的设置选项 1、打开手…

Python---字符串切片-----序列名称[开始位置下标 : 结束位置下标 : 步长]

字符串切片&#xff1a;是指对操作的对象截取其中一部分的操作。字符串、列表、元组都支持切片操作。 本文以字符串为例。 基本语法&#xff1a; 顾头不顾尾&#xff1a; ----------类似range&#xff08;&#xff09; 范围&#xff0c;顾头不顾尾 相关链接Python----ran…

YOLOv5 - yolov5s.yaml 文件

基于深度学习的目标检测模型的结构:输入->主干->脖子->头->输出。主干网络提取特征&#xff0c;脖子提取一些更复杂的特征&#xff0c;然后头部计算预测输出。 YOLOv5网络结构主要由以下几部分组成: 骨干网络(Backbone) &#xff1a;Backbone:骨干网络&#xff0c…

JAVA虚拟机-第2章 Java自动内存管理-异常实践

Java堆溢出 堆的参数设置&#xff1a;将堆的最小值-Xms参数与最大值-Xmx参数设置 public class HeapOOM {static class OOMObject {}public static void main(String[] args) {List<OOMObject> list new ArrayList<OOMObject>();while (true) {list.add(new OO…

FRI及相关SNARKs的Fiat-Shamir安全

1. 引言 本文主要参考&#xff1a; Alexander R. Block 2023年论文 Fiat-Shamir Security of FRI and Related SNARKsAlbert Garreta 2023年9月在ZK Summit 10上分享 ZK10: Fiat-Shamir security of FRI and related SNARKs - Albert Garreta (Nethermind) 评估参数用的Sage…

【Git企业开发】第五节.远程操作

文章目录 前言一、理解分布式版本控制系统二、远程仓库 2.1 新建远程仓库 2.2 克隆远程仓库 2.3 向远程仓库推送 2.4 拉取远程仓库总结 前言 一、理解分布式版本控制系统 我们目前所说的所有内容(工作区&#xff0c;暂存区&#xff0c;版本库等等)&#x…

100G QSFP28 BIDI LR1光模块最新解决方案

上期文章我们有介绍到100G QSFP28 BIDI ER1 Lite光模块&#xff0c;本期内容我们将继续为大家介绍100G光模块系列的100G QSFP28 BIDI LR1光模块。这款产品同样也在易天ECOC光通讯展展出&#xff0c;下面跟着小易一起来看看吧&#xff01; 易天光通信的100G QSFP28 BIDI LR1单纤…

【Linux学习笔记】进程概念(中)

1. 操作系统的进程状态2. Linux操作系统的进程状态3. 僵尸进程4. 孤儿进程5. 进程优先级5.1. 优先级是什么和为什么要有优先级5.2. Linux中的进程优先级 6. 进程切换7. 环境变量7.1. 环境变量的认识7.2. 环境变量相关的命令7.3. 环境变量和本地变量7.4. 命令行参数7.5. 获取环境…

突破防火墙的一种方法

当Linux防火墙阻止来自某个ip的数据时&#xff0c;它应该是根据ip数据报里“源IP地址”字段取得的对方ip吧&#xff0c;那对方就不能通过篡改“源IP地址”来绕过防火墙吗&#xff1f;NAT模式下的路由器就修改了这个字段。 但这样的话&#xff0c;攻击者是收不到服务器返回的数…

通过内网穿透分享本地电脑上有趣的照片:部署piwigo网页

通过cpolar分享本地电脑上有趣的照片&#xff1a;部署piwigo网页 文章目录 通过cpolar分享本地电脑上有趣的照片&#xff1a;部署piwigo网页前言1.Piwigo2. 使用phpstudy网页运行3. 创建网站4. 开始安装Piwogo5. 设定一条内网穿透数据隧道6. 与piwigo网站绑定7. 在创建隧道界面…

k8s 多网卡方案multus

kubernetes 多网卡方案之 Multus_CNI 部署以及基本使用 一、multus cni 出现的背景 在k8s的环境中启动一个容器&#xff0c;默认情况下只存在两个虚拟网络接口&#xff08;loopback 和 eth0&#xff09;&#xff0c; loopback 的流量始终都会在本容器内或本机循环&#xff0c…

CSAPP BOMB LAB part2

bomb lab part2 phase3 汇编语法 switch 汇编版本 switch 例子: switch 使用 jump table movl 指令 cmpl指令是x86汇编语言中的一个比较指令&#xff0c;用于比较两个操作数的值。cmpl指令的格式如下&#xff1a; cmpl source, destinationsource和destination可以是…

为什么我电脑上C:\Windows\System32\config\regback文件夹是空的,怎么设置才能有备份文件

环境&#xff1a; Win10 专业版 19041 问题描述&#xff1a; 为什么我电脑上C:\Windows\System32\config\regback文件夹是空的&#xff0c;怎么设置才能有备份文件 解决方案&#xff1a; 微软说从 Windows 10 版本 1803 开始&#xff0c;系统注册表不再备份到 RegBack 文件…

第二章 线性表【数据结构与算法】【精致版】

第二章 线性表【数据结构与算法】【精致版】 前言版权第二章 线性表2.1 应用实例应用实例一 约瑟夫环问题(Josephus problem)应用实例二 一元多项式运算器 2.2 线性表的概念及运算2.2.1线性表的逻辑结构2.2.2 线性表的运算 2.3 线性表的顺序存储2.3.1 顺序表2.3.2 顺序表的基本…

网络安全进阶学习第二十一课——XXE

文章目录 一、XXE简介二、XXE原理三、XXE危害四、XXE如何寻找五、XXE限制条件六、XXE分类七、XXE利用1、读取任意文件1.1、有回显1.2、没有回显 2、命令执行&#xff08;情况相对较少见&#xff09;3、内网探测/SSRF4、拒绝服务攻击(DDoS)4.1、内部实体4.2、参数实体 八、绕过基…

制造企业如何三步实现进销存管理?

制造企业如何三步实现进销存管理&#xff1f; 一、什么是进销存软件&#xff1f; 进销存软件是一种针对制造业企业设计的管理软件系统&#xff0c;旨在协调和优化企业的生产、采购、销售以及库存管理等方面的活动。该系统的主要目标是提高企业的生产效率、降低库存成本、优化…