【python科目一:生产线系统设计;激光刀切割材料】
工厂有若干条生产线,可以生产不同型号的产品,要求实现功能如下:1. ProductionLineMgmtSys 初始化生产线和产品的生产周期有num条生产线,编号从0开始periods[i]表示生产一个型号为i的产品所需的生产周期,单位为天2. Produce 在生产线assemblyId上,从日期date开始持续生产型号productId的产品若生产线空闲,开始生产并返回1若生产线正在生产该型号产品,则命令忽略,返回0若正在生产其他型号,立刻切换,返回-1产品完成日期:若某生产线在date开始生产某型号产品,生产周期为period,则日期date+N*period均为「产品完成日期」假设date为2,period为3,则完成日期为5、8、11...生产切换规则:若非在产品完成日期发生切换,则正在生产的产品未完成,废弃不计若在产品完成日期发生切换,则计数,并同时启动下一产品的生产。3. GetProductCount 查询截止date(含),累计完成型号productId的产品数量。生产完成即 产品完成日期<=date
输入输出样例:
["ProductionLineMgmtSys","produce","getProductCount","getProductCount"]
[[2,[1,3]],[0,1,1],[8,1],[9,1]]
[null,1,2,3]["ProductionLineMgmtSys","produce","produce","getProductCount","produce","produce","getProductCount","produce","produce","produce","getProductCount","produce"]
[[5,[1,4,5,8,2,3]],[0,1,0],[1,1,5],[4,0],[5,0,5],[7,0,0],[7,5],[8,1,5],[8,4,0],[9,1,0],[10,0],[1000,4,0]]
[null,1,-1,1,1,-1,2,0,1,-1,7,0]题给代码:
class ProductionLineMgmtSys {public:ProductionLineMgmtSys(int num, const vector<int>& periods){}int Produce(int date, int assemblyId, int productId){}int GetProductCount(int date, int productId){}
};
from typing import List
import copyclass ProductionLineMgmtSys:def __init__(self, num: int, periods: List[int]):
self.produc_line = dict.fromkeys(range(num)) #key:生产线id value:生产产品id
self.produc_number = dict.fromkeys(range(len(periods)), 0) #key:产品id value:生产数量
self.produc_line_product_start_date = dict.fromkeys(range(num)) #key:生产线id value:生产产品开始时间
self.periods = periodsdef produce(self, date: int, assembly_id: int, product_id: int) -> int:
if self.produc_line[assembly_id] == None:
self.produc_line[assembly_id] = product_id
self.produc_line_product_start_date[assembly_id] = date
return 1
elif self.produc_line[assembly_id] == product_id:
return 0
else:
i = 0
while(self.produc_line_product_start_date[assembly_id] + i * self.periods[self.produc_line[assembly_id]] <= date):
i += 1
self.produc_number[self.produc_line[assembly_id]] += i - 1
self.produc_line_product_start_date[assembly_id] = date
self.produc_line[assembly_id] = product_id
return -1def get_product_count(self, date: int, product_id: int) -> int:
product_achive_number = 0
if product_id in self.produc_line.values():
product_id_in_produc_line = [i for i,x in enumerate(self.produc_line.values()) if x == product_id]
#该生产线还在生产对应产品
produc_number1 = copy.deepcopy(self.produc_number)
for assembly_id1 in product_id_in_produc_line:
i = 0
while(self.produc_line_product_start_date[assembly_id1] + i * self.periods[product_id] <= date):
i += 1
produc_number1[product_id] += copy.deepcopy(i - 1)
product_achive_number += copy.deepcopy(produc_number1[product_id])
else:
product_achive_number = copy.deepcopy(self.produc_number[product_id])
return product_achive_numberif __name__ == '__main__':# ms = ProductionLineMgmtSys(2,[1,3])
# p = ms.produce(0,1,1)
# g = ms.get_product_count(8,1)
# g1 = ms.get_product_count(9,1)
#["ProductionLineMgmtSys","produce","produce","getProductCount","produce","produce","getProductCount","produce","produce","produce","getProductCount","produce"]
#
#[[5,[1,4,5,8,2,3]],[0,1,0],[1,1,5],[4,0],[5,0,5],[7,0,0],[7,5],[8,1,5],[8,4,0],[9,1,0],[10,0],[1000,4,0]]ms = ProductionLineMgmtSys(5,[1,4,5,8,2,3])
p1 = ms.produce(0,1,0)
p2 = ms.produce(1,1,5)
g3 = ms.get_product_count(4,0)
p4 = ms.produce(5,0,5)
p5 = ms.produce(7,0,0)
g6 = ms.get_product_count(7,5)
p7 = ms.produce(8,1,5)
p8 = ms.produce(8,4,0)
p9 = ms.produce(9,1,0)
g10 = ms.get_product_count(10,0)
p11 = ms.produce(1000,4,0)
s = 2
某工厂使用激光刀切割材料。激光刀具有开启和关闭两种状态,并可转向和移动。支持指令如下:
O —— 开启激光刀(即 “OPEN”),指令执行后激光刀处于开启状态
C —— 关闭激光刀(即 “CLOSE”),指令执行后激光刀处于关闭状态
M —— 激光刀沿着当前方向前进一段距离(即 “MOV”),若激光刀在开启状态下,会同步进行材料切割,否则只移动不切割
U,D,L,R —— 改变激光刀的前进方向、但不移动(上:U,下:D,左:L,右:R)
给定一块高为 height,宽为 width 的材料。初始时,激光刀位于材料左上角,处于关闭状态,前进方向为朝下 (D)。
激光刀的操作指令依次记录于字符串 operations,所有 M 指令的移动距离依次记录于数组 distances,distances[i] 表示第 i 个 M 指令的移动距离。
请计算完成操作指令后,材料板上被切割出了多少个 1 x 1 的方块。
注意:输入数据保证激光刀始终在材料初始范围内,可在材料边上,即:激光刀的位置 [row, col] 始终满足 0 <= row <= height,0 <= col <= width。
示例 1:
输入:
height = 3
width = 4
operations = “MRMOMDMLMUMCRMODMC”
distances = [1,1,2,1,2,2,1,2]
输出:3
解释:operations 中有 8 个 M,对应的移动距离在数组distances中。
如图所示,激光刀移动的位置顺序 0->1->2->3->…->8 。其中黄色的线是激光刀开启情形下切割的路径。这样最终图中的 3 个阴影位置是切割所得的 1 x 1 方块。

示例 2:
输入:
height = 3
width = 4
operations = “MRMOMDMLMUMC”
distances = [1,1,2,1,2,2]
输出:0
解释:如图所示,没有切割出 1 x 1 的方块,故返回 0。
注意:下图中切出的是一个 2 x 1 的材料块,不是两个 1 x 1 的方块。

示例 3:
输入:
height = 3
width = 3
operations = “MROMDMLMUMRMDMRMUMLMC”
distances = [1,2,1,2,1,1,1,1,1,1]
输出:2
提示:
1 <= height, width <= 100
0 <= operations.length <= 10^4
distances.length 等于 operations 中 M 的个数
operations[i] 仅为 ‘O’、‘C’、‘U’、‘D’、‘L’、‘R’、‘M’
一条边可能会被多次切割
解题思路: 判断格子的四条边是否被切割过, 一共有水平边w * (h + 1) ,垂直边 h * (w + 1)
from typing import Listclass Solution:def __init__(self):self.block_num = 0self.line_h = []self.line_v = []def init_block(self, height, width):self.line_h = [[0 for _ in range(width)] for _ in range(height + 1)]self.line_v = [[0 for _ in range(height)] for _ in range(width + 1)]for x in range(0, width):self.line_h[0][x] = 1self.line_h[height][x] = 1for y in range(0, height):self.line_v[0][y] = 1self.line_v[width][y] = 1def mv_knife(self, height: int, width: int, operations: str, distances: List[int]):knife_status = 'C'move_command = 'D'command_count = -1cur_x = 0cur_y = 0for command in list(operations):if command == 'O' or command == 'C':knife_status = commandcontinueelif command == 'M':command_count += 1else:move_command = commandcontinueif move_command == 'U':next_y = cur_y - distances[command_count]if knife_status == 'O':for position in range(next_y, cur_y):self.line_v[cur_x][position] = 1cur_y = next_yelif move_command == 'D':next_y = cur_y + distances[command_count]if knife_status == 'O':for position in range(cur_y, next_y):self.line_v[cur_x][position] = 1cur_y = next_yelif move_command == 'L':next_x = cur_x - distances[command_count]if knife_status == 'O':for position in range(next_x, cur_x):self.line_h[cur_y][position] = 1cur_x = next_xelif move_command == 'R':next_x = cur_x + distances[command_count]if knife_status == 'O':for position in range(cur_x, next_x):self.line_h[cur_y][position] = 1cur_x = next_xdef get_block_num(self, height, width):for x in range(0, width):for y in range(0, height):if self.line_h[y][x] and self.line_h[y + 1][x] and self.line_v[x][y] and self.line_v[x + 1][y]:self.block_num += 1return self.block_numdef get_unit_block_num(self, height: int, width: int, operations: str, distances: List[int]) -> int:self.init_block(height, width)self.mv_knife(height, width, operations, distances)self.get_block_num(height, width)return self.block_numheight = 3
width = 4
operations = "MRMOMDMLMUMCRMODMC"
distances = [1, 1, 2, 1, 2, 2, 1, 2]ss = Solution()
print(ss.get_unit_block_num(height, width, operations, distances))
相关文章:
【python科目一:生产线系统设计;激光刀切割材料】
工厂有若干条生产线,可以生产不同型号的产品,要求实现功能如下:1. ProductionLineMgmtSys 初始化生产线和产品的生产周期有num条生产线,编号从0开始periods[i]表示生产一个型号为i的产品所需的生产周期,单位为天2. Pro…...
Linux——进程概念(进程状态)
目录 进程状态 三态模型 五态模型 七态模型 Example eg1:阻塞态:等待某种资源的过程 eg2:挂起态 Linux内核源代码 Linux进程状态查看 Linux运行状态 R运行状态(running): S睡眠状态(sleeping): D磁盘休眠状…...
超详细:正则表达式从入门到入门
文章目录匹配字符\d \D\s \S量词:匹配多个字符星号*加号问号?大括号{}集合字符[]明确字符范围字符补集字符常见字符集贪婪模式和非贪婪模式匹配开头和结尾贪婪模式和非贪婪模式常用函数re.findall()re.search()re.compile()re.split()re.sub()本文章首发…...
jupyter notebook小技巧
1、.ipynb 文件转word文档 将 jupyter notebook(.ipynb 文件)转换为 word 文件(.docx)的最简单方法是使用 pandoc。 首先安装pip install pandoc, 安装后,在将 Jupyter notebook文件目录cmd 然后输入打开…...
考研复试机试 | c++ | 王道复试班
目录n的阶乘 (清华上机)题目描述代码汉诺塔问题题目:代码:Fibonacci数列 (上交复试)题目代码:二叉树:题目:代码:n的阶乘 (清华上机) …...
js闭包简单理解
js里面的闭包是一个难点也是它的一个特色,是我们必须掌握的js高级特性,那么什么是闭包呢?它又有什么作用呢? 1,提到闭包我们这里先讲解一下js作用域的问题 js的作用域分两种,全局和局部,基于我…...
「JVM 编译优化」编译器优化技术
后端编译(即时编译、提前编译)的目标时将字节码翻译成本地机器码,而难点是输出优化质量较高的机器码; 文章目录1. 优化技术概览2. 方法内联(Inlining)3. 逃逸分析(Escape Analysis)4…...
回溯问题(子集型回溯、组合型回溯、排列型回溯)【零神基础精讲】
来源0x3f:https://space.bilibili.com/206214 回溯分为【子集型回溯】【组合型回溯】【排列型回溯】 文章目录回溯基本概念[17. 电话号码的字母组合](https://leetcode.cn/problems/letter-combinations-of-a-phone-number/)子集型回溯(分割问题也可以看…...
源代码配置安装Apache
源代码配置安装Apache 📒博客主页: 微笑的段嘉许博客主页 💻微信公众号:微笑的段嘉许 🎉欢迎关注🔎点赞👍收藏⭐留言📝 📌本文由微笑的段嘉许原创! …...
css水平垂直居中各种方法实现方式
不定宽高水平垂直居中? 面试题回答方式: 通过display:flex;justify-content:center; align-items:center;就可以让子元素不定宽高水平垂直居中 也可以父display:flex;,子设置一个margin&#…...
PowerShell Install java 13
java 前言 Java具有大部分编程语言所共有的一些特征,被特意设计用于互联网的分布式环境。Java具有类似于C语言的形式和感觉,但它要比C语言更易于使用,而且在编程时彻底采用了一种以对象为导向的方式。 java download javadownloadPowersh…...
Python的PyQt框架的使用(汇总)
Python的PyQt框架的使用一、前言二、安装PyQt三、使用第三方开发工具四 、创建主窗体五、常用控件篇1.QLineEdit 文本框2.QPushButton按钮控件3.QRadioButton 单选按钮六、布局管理篇1.通过布局管理器布局2.绝对布局七、信号与槽的关联1.编辑信号/槽2.信号/槽编辑器八、资源文件…...
力扣热题100Day05:15.三数之和,17. 电话号码的字母组合,19. 删除链表的倒数第 N 个结点
15.三数之和 题目链接:15. 三数之和 - 力扣(Leetcode) 思路: (1)双指针,在外层for循环里加入两个指针,left和right (2)排序:为了更好地进行去…...
探索开源:获取完整的 GitHub 社区数据集
本篇文章聊聊 GitHub 开放数据集的获取和整理,分享一些数据整理的细节技巧,以及一些相对粗浅的数据背后的事情。 写在前面 分析 GitHub 上的项目和开发者获取是深入、真实的了解开源世界演进的方法之一。 在 GHArchive 项目中,我们能够看到…...
github ssh密钥配置,克隆远程仓库
GitHub的SSH配置 在往github上push项目的时候,如果走https的方式,每次都需要输入账号密码,非常麻烦。而采用ssh的方式,就不再需要输入,只需要在github自己账号下配置一个ssh key即可! 很多朋友在用github管…...
突破年薪百万难关!吃透这套Java真题合集
前言我相信大多 Java 开发的程序员或多或少经历过BAT一些大厂的面试,也清楚一线互联网大厂 Java 面试是有一定难度的,小编经历过多次面试,有满意的也有备受打击的。因此呢小编想把自己这么多次面试经历以及近期的面试真题来个汇总分析&#x…...
[黑马程序员SSM框架教程] Spring-11-setter注入
思考:向一个类中传递数据要几种? set方法构造方法 思考:依赖注入描述了在容器中建立bean与bean之间依赖关系的过程,如果bean运行需要数字或字符呢 引用类型简单类型(基本数据类型和字符串) 注入方式&#x…...
Java多线程(一)--多线程基础知识
1. 为什么要使用并发编程提升多核CPU的利用率:一般来说一台主机上的会有多个CPU核心,我们可以创建多个线程,理论上讲操作系统可以将多个线程分配给不同的CPU去执行,每个CPU执行一个线程,这样就提高了CPU的使用效率&…...
AutoDock, AutoDock-vina等对接工具安装
AutoDock, AutoDock-vina等对接工具安装 AutoDock-GPU安装 下载地址: https://autodock.scripps.edu/downloads/ 将压缩包传送至安装目录中,并解压到当前路径 unzip AutoDock-GPU-develop.zip 找到服务器的cuda的路径,cuda的路径一般默认…...
MySQL常见面试题(2023年最新)
目录1.char和varchar的区别2.数据库的三大范式3.索引是什么4.索引的优点和缺点5.索引怎么设计(优化)6.索引的类型7.索引的数据类型8.索引为什么使用树结构9.二叉查找树、B树、B树10.为什么使用B树不用B树11.最左匹配原则12.MylSAM和InnoDB的区别13.什么是事务14.事务的四大特性…...
【大模型RAG】拍照搜题技术架构速览:三层管道、两级检索、兜底大模型
摘要 拍照搜题系统采用“三层管道(多模态 OCR → 语义检索 → 答案渲染)、两级检索(倒排 BM25 向量 HNSW)并以大语言模型兜底”的整体框架: 多模态 OCR 层 将题目图片经过超分、去噪、倾斜校正后,分别用…...
变量 varablie 声明- Rust 变量 let mut 声明与 C/C++ 变量声明对比分析
一、变量声明设计:let 与 mut 的哲学解析 Rust 采用 let 声明变量并通过 mut 显式标记可变性,这种设计体现了语言的核心哲学。以下是深度解析: 1.1 设计理念剖析 安全优先原则:默认不可变强制开发者明确声明意图 let x 5; …...
DIY|Mac 搭建 ESP-IDF 开发环境及编译小智 AI
前一阵子在百度 AI 开发者大会上,看到基于小智 AI DIY 玩具的演示,感觉有点意思,想着自己也来试试。 如果只是想烧录现成的固件,乐鑫官方除了提供了 Windows 版本的 Flash 下载工具 之外,还提供了基于网页版的 ESP LA…...
Pinocchio 库详解及其在足式机器人上的应用
Pinocchio 库详解及其在足式机器人上的应用 Pinocchio (Pinocchio is not only a nose) 是一个开源的 C 库,专门用于快速计算机器人模型的正向运动学、逆向运动学、雅可比矩阵、动力学和动力学导数。它主要关注效率和准确性,并提供了一个通用的框架&…...
R语言速释制剂QBD解决方案之三
本文是《Quality by Design for ANDAs: An Example for Immediate-Release Dosage Forms》第一个处方的R语言解决方案。 第一个处方研究评估原料药粒径分布、MCC/Lactose比例、崩解剂用量对制剂CQAs的影响。 第二处方研究用于理解颗粒外加硬脂酸镁和滑石粉对片剂质量和可生产…...
Java毕业设计:WML信息查询与后端信息发布系统开发
JAVAWML信息查询与后端信息发布系统实现 一、系统概述 本系统基于Java和WML(无线标记语言)技术开发,实现了移动设备上的信息查询与后端信息发布功能。系统采用B/S架构,服务器端使用Java Servlet处理请求,数据库采用MySQL存储信息࿰…...
多模态图像修复系统:基于深度学习的图片修复实现
多模态图像修复系统:基于深度学习的图片修复实现 1. 系统概述 本系统使用多模态大模型(Stable Diffusion Inpainting)实现图像修复功能,结合文本描述和图片输入,对指定区域进行内容修复。系统包含完整的数据处理、模型训练、推理部署流程。 import torch import numpy …...
tomcat入门
1 tomcat 是什么 apache开发的web服务器可以为java web程序提供运行环境tomcat是一款高效,稳定,易于使用的web服务器tomcathttp服务器Servlet服务器 2 tomcat 目录介绍 -bin #存放tomcat的脚本 -conf #存放tomcat的配置文件 ---catalina.policy #to…...
【p2p、分布式,区块链笔记 MESH】Bluetooth蓝牙通信 BLE Mesh协议的拓扑结构 定向转发机制
目录 节点的功能承载层(GATT/Adv)局限性: 拓扑关系定向转发机制定向转发意义 CG 节点的功能 节点的功能由节点支持的特性和功能决定。所有节点都能够发送和接收网格消息。节点还可以选择支持一个或多个附加功能,如 Configuration …...
Chrome 浏览器前端与客户端双向通信实战
Chrome 前端(即页面 JS / Web UI)与客户端(C 后端)的交互机制,是 Chromium 架构中非常核心的一环。下面我将按常见场景,从通道、流程、技术栈几个角度做一套完整的分析,特别适合你这种在分析和改…...
