【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.事务的四大特性…...

C# 泛型详解
C# 泛型详解1、泛型概述2、定义泛型3、泛型的特性4、泛型委托5、泛型的优点在 C# 中,泛型(Generic)是一种规范,它允许我们使用占位符来定义类和方法,编译器会在编译时将这些占位符替换为指定的类型,利用泛型…...

数据仓库相关术语
数据仓库数据集市事实维度级别数据清洗数据采集数据转换联机分析处理(OLAP OnlineAnalytical Processing )切片切块星型模式雪花模式粒度度量度量值口径指标 原子指标:派生指标衍生指标标签自然键持久键代理键退化维度下钻上卷T0与T1数据挖掘数据科学家总线架构总线…...

【IDEA】常用快捷键
代码补全 快捷键说明sout快速输出System.out.println();psvm快速输出public static void main(String[] args) {}Ctrl Alt Space代码补全 编辑类 快捷键说明Shift Enter向下键入一行,并将光标移到下一行的开头Ctrl Alt Enter当前行上方生成空行,并…...

【调试】sysRq按键使用方法
SysRq键简介 SysRq键是一个魔术案件,只要在内核没有完全卡死的情况下,内核都会相应SysRq 键的输入,使用这些组合键都可以搜集包括系统内存使用、CPU任务处理、进程运行状态等系统运行信息。 配置 内核配置选项中要使能CONFIG_MAGIC_SYSRQ选…...

Jenkins Pipeline 语法
官网 ## https://www.jenkins.io/doc/book/pipeline/ 参考文章 ## https://www.jianshu.com/p/215584419f3d 根据Jenkins官网Pipeline给出的解释, 流水线语法分为两种, 一种是声明式流水线(Declarative Pipeline)另一种是脚本…...

rust语言实现超级简单的杀毒软件,通过哈希扫描病毒。
以下是一个简单的rust语言程序,用于扫描病毒文件并使用哈希表进行比较。该程序可以扫描指定目录中的所有文件,并查找其中是否包含特定的病毒文件。程序可以通过计算文件哈希值并将其与已知的病毒哈希值进行比较来确定文件是否是病毒。注意,这…...

Git仓库中的常用命令
1.第一次使用Git软件前,告诉Git你是谁 git config --global user.name "自定义用户名" git config --global user.email "用户邮箱" 2.查看配置列表 git config --list 3.初始化一个Git仓库,用来管理当前项目 git i…...

arduino和stm32和51和TSM32的区别,树莓派和jetson nano的区别
本科时段接触过很多嵌入式的微处理器和微控制器,但对其使用场景和区别一直没有一个总结,这次收集了一些信息在这总结一下。 Arduino、STM32、51、TMS320和树莓派和jetson nano都是不同的嵌入式系统,它们之间有以下的区别: 开发难度…...

如何进行nginx的负载配置
示例://多机负载策略:加权轮询(适用于服务器无状态,并且服务器硬件配置不均衡的场景)upstream setServ { server 47.100.110.58:80 weight1; server 47.100.110.59:8080 weight4; }location / {//转发到负载服务上proxy_pass http://setServ;}注意&#…...

从功能测试进阶自动化测试,熬夜7天整理出这一份3000字超全学习指南
一、为什么要学习自动化测试? 如果在前两年,可能10个测试员有6个都是做的功能测试,但随着测试技术的发展以及测试工作的深入,传统的手工测试已经无法满足多模块的测试需求,所以为了提高测试效率和测试质量,…...