华为OD机试-高性能AI处理器-2022Q4 A卷-Py/Java/JS
某公司研发了一款高性能AI处理器。每台物理设备具备8颗AI处理器,编号分别为0、1、2、3、4、5、6、7。
编号0-3的处理器处于同一个链路中,编号4-7的处理器处于另外一个链路中,不同链路中的处理器不能通信。
现给定服务器可用的处理器编号数组array,以及任务申请的处理器数量num,找出符合下列亲和性调度原则的芯片组合。
如果不存在符合要求的组合,则返回空列表。
亲和性调度原则:
-如果申请处理器个数为1,则选择同一链路,剩余可用的处理器数量为1个的最佳,其次是剩余3个的为次佳,然后是剩余2个,最后是剩余4个。
-如果申请处理器个数为2,则选择同一链路剩余可用的处理器数量2个的为最佳,其次是剩余4个,最后是剩余3个。
-如果申请处理器个数为4,则必须选择同一链路剩余可用的处理器数量为4个。
-如果申请处理器个数为8,则申请节点所有8个处理器。
提示:
任务申请的处理器数量只能是1、2、4、8。
编号0-3的处理器处于一个链路,编号4-7的处理器处于另外一个链路。
处理器编号唯一,且不存在相同编号处理器。
输入描述
输入包含可用的处理器编号数组array,以及任务申请的处理器数量num两个部分。
第一行为array,第二行为num。例如:
[0, 1, 4, 5, 6, 7]
表示当前编号为0、1、4、5、6、7的处理器可用。任务申请1个处理器。
0 <= array.length <= 8
0 <= array[i] <= 7
num in [1, 2, 4, 8]
输出描述
输出为组合列表,当array=[0,1,4,5,6,7],num=1 时,输出为[[0], [1]]。
示例1 输入输出示例仅供调试,后台判题数据一般不包含示例
输入
[0, 1, 4, 5, 6, 7]
输出
[[0], [1]]
说明
根据第一条亲和性调度原则,在剩余两个处理器的链路(0, 1, 2, 3)中选择处理器。
由于只有0和1可用,则返回任意一颗处理器即可。
Java 代码
import java.util.Scanner;
import java.util.*;
import java.util.stream.Stream;
import java.util.stream.Collectors;class Main {public static void main(String[] args) {// 处理输入Scanner in = new Scanner(System.in);Integer[] cores = Arrays.stream(in.nextLine().split("[\\[\\]\\,\\s]")).filter(str -> !"".equals(str)).map(Integer::parseInt).toArray(Integer[]::new);int target = in.nextInt();//初始化两个链路剩余可用的处理器ArrayList<Integer> processors_1 = new ArrayList<>();ArrayList<Integer> processors_2 = new ArrayList<>();Arrays.sort(cores, (a, b) -> a - b);for (Integer core : cores) {if (core < 4) {processors_1.add(core);} else {processors_2.add(core);}}ArrayList<ArrayList<Integer>> result = new ArrayList<>();int length_1 = processors_1.size();int length_2 = processors_2.size();switch (target) {case 1:if (length_1 == 1 || length_2 == 1) {if (length_1 == 1) dfs(processors_1, 0, 1, new ArrayList<>(), result);if (length_2 == 1) dfs(processors_2, 0, 1, new ArrayList<>(), result);} else if (length_1 == 3 || length_2 == 3) {if (length_1 == 3) dfs(processors_1, 0, 1, new ArrayList<>(), result);if (length_2 == 3) dfs(processors_2, 0, 1, new ArrayList<>(), result);} else if (length_1 == 2 || length_2 == 2) {if (length_1 == 2) dfs(processors_1, 0, 1, new ArrayList<>(), result);if (length_2 == 2) dfs(processors_2, 0, 1, new ArrayList<>(), result);} else if (length_1 == 4 || length_2 == 4) {if (length_1 == 4) dfs(processors_1, 0, 1, new ArrayList<>(), result);if (length_2 == 4) dfs(processors_2, 0, 1, new ArrayList<>(), result);}break;case 2:if (length_1 == 2 || length_2 == 2) {if (length_1 == 2) dfs(processors_1, 0, 2, new ArrayList<>(), result);if (length_2 == 2) dfs(processors_2, 0, 2, new ArrayList<>(), result);} else if (length_1 == 4 || length_2 == 4) {if (length_1 == 4) dfs(processors_1, 0, 2, new ArrayList<>(), result);if (length_2 == 4) dfs(processors_2, 0, 2, new ArrayList<>(), result);} else if (length_1 == 3 || length_2 == 3) {if (length_1 == 3) dfs(processors_1, 0, 2, new ArrayList<>(), result);if (length_2 == 3) dfs(processors_2, 0, 2, new ArrayList<>(), result);}break;case 4:if (length_1 == 4 || length_2 == 4) {if (length_1 == 4) result.add(processors_1);if (length_2 == 4) result.add(processors_2);}break;case 8:if (length_1 == 4 && length_2 == 4) {result.add(Stream.concat(processors_1.stream(), processors_2.stream()).collect(Collectors.toCollection(ArrayList<Integer>::new)));}break;}System.out.println(result.toString());}public static void dfs(ArrayList<Integer> cores,int index,int level,ArrayList<Integer> path,ArrayList<ArrayList<Integer>> res) {if (path.size() == level) {res.add((ArrayList<Integer>) path.clone());return;}for (int i = index; i < cores.size(); i++) {path.add(cores.get(i));// 逐个往后找合适的组合dfs(cores, i + 1, level, path, res);path.remove(path.size() - 1);}}
}
Python代码
import functools
import collections
import math
from itertools import combinations
from re import match
import copyclass TreeNode:def __init__(self, val=0, left=None, right=None):self.val = valself.left = leftself.right = right#并查集模板
class UF:def __init__(self, n=0):self.count = nself.item = [0 for x in range(n+1)]for i in range(n):self.item[i] = idef find(self, x):if (x != self.item[x]):self.item[x] = self.find(self.item[x])return 0return xdef union_connect(self, x, y):x_item = self.find(x)y_item = self.find(y)if (x_item != y_item):self.item[y_item] = x_itemself.count-=1# 处理输入
v = [int(x) for x in input()[1:-1].split(",")]#初始化两个链路剩余可用的处理器
processors_1 = []
processors_2 = []
for x in v:if (x >= 4):processors_2.append(x)else:processors_1.append(x)length_1 = len(processors_1)
length_2 = len(processors_2)# 申请的处理器个数
apply_num = int(input())#满足条件结果组合
result = []def dfs(batch_processor,index, level, path):if (len(path) == level):result.append(copy.copy(path))return for i in range(index, len(batch_processor)):path.append(batch_processor[i])# 逐个往后找合适的组合dfs(batch_processor, i + 1, level, path)path.pop()def get_combo(batch_processor, num):path=[]dfs(batch_processor, 0, num, path)if (apply_num == 1):# 原则1if (length_1 == 1 or length_2 == 1):if (length_1 == 1): get_combo(processors_1, 1)if (length_2 == 1): get_combo(processors_2, 1)elif (length_1 == 3 or length_2 == 3):if (length_1 == 3): get_combo(processors_1, 1)if (length_2 == 3): get_combo(processors_2, 1)elif (length_1 == 2 or length_2 == 2):if (length_1 == 2): get_combo(processors_1, 1)if (length_2 == 2): get_combo(processors_2, 1)elif (length_1 == 4 or length_2 == 4):if (length_1 == 4): get_combo(processors_1, 1)if (length_2 == 4): get_combo(processors_2, 1)elif (apply_num == 2):# 原则2if (length_1 == 2 or length_2 == 2):if (length_1 == 2): get_combo(processors_1, 2)if (length_2 == 2): get_combo(processors_2, 2)elif (length_1 == 4 or length_2 == 4):if (length_1 == 4): get_combo(processors_1, 2)if (length_2 == 4): get_combo(processors_2, 2)elif (length_1 == 3 or length_2 == 3):if (length_1 == 3): get_combo(processors_1, 2)if (length_2 == 3): get_combo(processors_2, 2)elif (apply_num == 4):# 原则3if (length_1 == 4 or length_2 == 4):if (length_1 == 4): result.append(processors_1)if (length_2 == 4): result.append(processors_2)elif (apply_num == 8):# 原则4if (length_1 == 4 and length_2 == 4):processors_2 = processors_2 + processors_1result.append(processors_2)result = [str(x) for x in result]
print("[" +", ".join(result)+ "]")
JS代码
let result = []function dfs(batch_processor,index, level, path){if (path.length == level){result.push([...path])return }for (let i=index;i<batch_processor.length;i++){path.push(batch_processor[i])// 逐个往后找合适的组合dfs(batch_processor, i + 1, level, path)path.pop()}
}function get_combo(batch_processor, num){let path=[]dfs(batch_processor, 0, num, path)
}function main(v, apply_num) {//初始化两个链路剩余可用的处理器let processors_1 = []let processors_2 = []for (let x of v){if (x >= 4)processors_2.push(x)elseprocessors_1.push(x)}let length_1 = processors_1.lengthlet length_2 = processors_2.lengthif (apply_num == 1){// 原则1if (length_1 == 1 || length_2 == 1){if (length_1 == 1)get_combo(processors_1, 1)if (length_2 == 1)get_combo(processors_2, 1)}else if (length_1 == 3 || length_2 == 3){if (length_1 == 3)get_combo(processors_1, 1)if (length_2 == 3)get_combo(processors_2, 1)}else if (length_1 == 2 || length_2 == 2){if (length_1 == 2)get_combo(processors_1, 1)if (length_2 == 2)get_combo(processors_2, 1)}else if (length_1 == 4 || length_2 == 4){if (length_1 == 4)get_combo(processors_1, 1)if (length_2 == 4)get_combo(processors_2, 1)}}else if (apply_num == 2){// 原则2if (length_1 == 2 || length_2 == 2){if (length_1 == 2)get_combo(processors_1, 2)if (length_2 == 2)get_combo(processors_2, 2)}else if (length_1 == 4 || length_2 == 4){if (length_1 == 4)get_combo(processors_1, 2)if (length_2 == 4)get_combo(processors_2, 2)}else if (length_1 == 3 || length_2 == 3){if (length_1 == 3)get_combo(processors_1, 2)if (length_2 == 3)get_combo(processors_2, 2)}}else if (apply_num == 4){// 原则3if (length_1 == 4 || length_2 == 4){if (length_1 == 4)result.push(processors_1)if (length_2 == 4)result.push(processors_2)}} else if (apply_num == 8){// 原则4if (length_1 == 4 && length_2 == 4){processors_2 = processors_2 + processors_1result.push(processors_2)}}console.log(result)}main([0, 1, 4, 5, 6, 7], 1)
相关文章:
华为OD机试-高性能AI处理器-2022Q4 A卷-Py/Java/JS
某公司研发了一款高性能AI处理器。每台物理设备具备8颗AI处理器,编号分别为0、1、2、3、4、5、6、7。 编号0-3的处理器处于同一个链路中,编号4-7的处理器处于另外一个链路中,不同链路中的处理器不能通信。 现给定服务器可用的处理器编号数组…...

Vue - 实现垂直菜单分类栏目,鼠标移入后右侧出现悬浮二级菜单容器效果(完整示例源码,详细代码注释,一键复制开箱即用)
前言 网上的教程都太乱了,各种杂乱无注释代码、图片资源丢失、一堆样式代码,根本无法改造后应用到自己的项目中。 本文实现了 在 Vue / Nuxt 项目中,垂直分类菜单项,当用户鼠标移入菜单后,右侧自动出现二级分类悬浮容器盒子效果, 您可以直接复制源码,然后按照您的需求再…...

NVM-无缝切换Node版本
NVM-无缝切换Node版本 如果未使用nvm之前已经下载了node,并且配置了环境变量,那么此时删除这些配置(Node的环境以及Node软件),使用nvm是为了在某些项目中使用低版本的node NVM下载 进入github的nvm readme: https://github.com/coreybutler/nvm-windows…...

CCF-CSP真题《202303-1 田地丈量》思路+python,c++满分题解
想查看其他题的真题及题解的同学可以前往查看:CCF-CSP真题附题解大全 试题编号:202303-1试题名称:田地丈量时间限制:1.0s内存限制:512.0MB问题描述: 问题描述 西西艾弗岛上散落着 n 块田地。每块田地可视为…...
Autosar-软件架构
文章目录 一、Autosar软件架构分层图二、应用层三、RTE层四、BSW层1、微控制器抽象层2、ECU抽象层I/O硬件抽象COM硬件抽象Memory硬件抽象Onboard Device Abstraction3、复杂驱动层4、服务层系统服务通信服务CAN一、Autosar软件架构分层图 架构分层是实现软硬件分离的关键,它也…...

8年测开年薪30W,为什么从开发转型为测试?谈谈这些年的心路历程……
谈谈我的以前,从毕业以来从事过两个多月的Oracle开发后转型为软件测试,到现在已近过去8年成长为一个测试开发工程师,总结一下之间的心路历程,希望能给徘徊在开发和测试之前的同学一点小小参考。 一、测试之路伏笔 上学偷懒&#…...

滑动奇异频谱分析:数据驱动的非平稳信号分解工具(Matlab代码实现)
💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…...

updateByPrimaryKey和updateByPrimaryKeySelective的区别
版权声明 本文原创作者:谷哥的小弟作者博客地址:http://blog.csdn.net/lfdfhl MyBatis Generator概述 MyBatis Generator是一个专门为MyBatis框架使用者定制的代码生成器,它可以快速的根据表生成对应的映射文件、接口文件、POJO。而且&#…...

【ARM Coresight 4 - Rom Table 介紹】
文章目录 1.1 ROM Table1.1.1 Entry 寄存器 1.2 ROM Table 例子 1.1 ROM Table 在一个SoC中,有多个Coresight 组件,但是软件怎么去识别这些 Coresight 组件,去获取这些Coresight 组件的信息了?这个时候,就需要靠 Core…...
11111111
单选题 1、某地上2层的仪表装配厂房,耐火等级二级,每层建筑面积10000m2,该厂 房二层设有800m2的金属零件抛光工段,采用耐火极限为2.00h的防火隔墙与其他区域分隔,该厂房的火灾危险性为( )。 正确答案:B A.甲类 B.乙类 C.丙…...

JavaWeb——TCP协议的相关特性
目录 一、TCP 1、特性 2、确认应答 (1)、定义 (2)、原理 (3)、接收缓冲区 3、超时重传 (1)、丢包 (2)、定义 (3)、分类 二、…...

数据结构(C语言实现)——二叉树的概念及二叉树顺序结构和链式结构的实现(堆排序+TOP-K问题+链式二叉树相关操作)
文章目录 1. 前言2. 树的概念及结构2.1 树的概念2.2 树的相关概念2.3 树的表示 3. 二叉树的概念3.1 特殊二叉树3.2 二叉树的性质 4. 二叉树的顺序存储4.1 堆的概念4.2 堆的实现4.2.1 堆的结点定义4.2.2 堆的打印和销毁4.2.3 堆的插入4.2.4 堆的删除4.2.5 取堆顶数据4.2.6 堆的判…...

OpenShift:关于OpenShift(OKD)通过命令行的方式部署镜像以及S2I流程Demo
写在前面 因为参加考试,会陆续分享一些 OpenShift 的笔记博文内容为安装完 OpenShift, 利用 OpenShift 引擎部署一个镜像应用和一个 S2I 流程部署应用 Demo学习环境为 openshift v3 的版本,有些旧这里如果专门学习 openshift ,建议学习 v4 版…...
楔形文字的破解(钉子形文字)【文字破译原理:信息的相关性】
文章目录 引言I 破解楔形文字1.1 贝希斯敦铭文1.2 破解古波斯楔形文字1.3 破解新埃兰楔形文字和巴比伦楔形文字1.4 破解苏美尔楔形文字引言 祖先借助外力走出了非洲,开始了农耕定居的生活,创造能量的水平和能量的使用效率都越来越高;依靠着语言、文字和书写系统,经验、技术…...

【网络安全】文件上传绕过思路
引言 分享一些文件上传绕过的思路,下文内容多包含实战图片,所以打码会非常严重,可多看文字表达;本文仅用于交流学习, 由于传播、利用此文所提供的信息而造成的任何直接或者间接的后果及损失,均由使用者本人…...
MySQL数据库(2)
目录 日期类型的基本使用 timestamp时间戳 修改表 insert基本使用 insert注意事项 update基本使用 update注意事项 delete基本使用 delete注意事项 select基本使用 select练习1 select练习2 select练习3 日期类型的基本使用 timestamp时间戳 在5.7版本使用时间戳需…...

2023年学什么编程语言,最容易找工作?
在众多行业中,程序员属于高薪职业。无论是在国外还是国内,程序员的薪金水平普遍高于其他行业的工作岗位,例如web前端开发、软件工程、游戏开发、APP开发、网络爬虫、网站开发、人工智能开发、网络维护、Java开发、大数据分析、Python开发等工…...
4月23日,今日信息差
1、京东健康皮肤医院正式上线 2、蚂蚁集团再捐1亿元支持内蒙古种树治沙 3、苹果MacBook组装商广达将投资1.2亿美元在越南建电脑制造厂 4、用友与百度签署战略合作协议 5、马斯克:星舰可能在一两个月后准备再次发射 6、格芯起诉IBM 恐波及日本2nm芯片计划 7、河北南部…...
【随笔四】JavaScript 中的 rest
某次开发中,看到项目代码中用到了 rest 这个参数,但又没看到在哪里定义或者传入,当时没太理解它的意思,查了下资料才恍然大悟。含义也很简单,写个随笔记录下。 关键字 rest 的用法(剩余参数) 在…...

maven作用讲解---以及怎么配置阿里的maven镜像
目录 Maven介绍 传统的java项目的结构和maven的对比 传统 Maven的项目 如何配置阿里 maven 2. 修改 Maven介绍 传统的java项目的结构和maven的对比 传统 Maven的项目 如何配置阿里 maven (1) 把 D:\program\JavaIDEA 2020.2\plugins\maven\lib\maven3\conf\settings.xml…...
从零实现富文本编辑器#5-编辑器选区模型的状态结构表达
先前我们总结了浏览器选区模型的交互策略,并且实现了基本的选区操作,还调研了自绘选区的实现。那么相对的,我们还需要设计编辑器的选区表达,也可以称为模型选区。编辑器中应用变更时的操作范围,就是以模型选区为基准来…...

MMaDA: Multimodal Large Diffusion Language Models
CODE : https://github.com/Gen-Verse/MMaDA Abstract 我们介绍了一种新型的多模态扩散基础模型MMaDA,它被设计用于在文本推理、多模态理解和文本到图像生成等不同领域实现卓越的性能。该方法的特点是三个关键创新:(i) MMaDA采用统一的扩散架构…...
【JavaSE】绘图与事件入门学习笔记
-Java绘图坐标体系 坐标体系-介绍 坐标原点位于左上角,以像素为单位。 在Java坐标系中,第一个是x坐标,表示当前位置为水平方向,距离坐标原点x个像素;第二个是y坐标,表示当前位置为垂直方向,距离坐标原点y个像素。 坐标体系-像素 …...

Maven 概述、安装、配置、仓库、私服详解
目录 1、Maven 概述 1.1 Maven 的定义 1.2 Maven 解决的问题 1.3 Maven 的核心特性与优势 2、Maven 安装 2.1 下载 Maven 2.2 安装配置 Maven 2.3 测试安装 2.4 修改 Maven 本地仓库的默认路径 3、Maven 配置 3.1 配置本地仓库 3.2 配置 JDK 3.3 IDEA 配置本地 Ma…...
AGain DB和倍数增益的关系
我在设置一款索尼CMOS芯片时,Again增益0db变化为6DB,画面的变化只有2倍DN的增益,比如10变为20。 这与dB和线性增益的关系以及传感器处理流程有关。以下是具体原因分析: 1. dB与线性增益的换算关系 6dB对应的理论线性增益应为&…...

R语言速释制剂QBD解决方案之三
本文是《Quality by Design for ANDAs: An Example for Immediate-Release Dosage Forms》第一个处方的R语言解决方案。 第一个处方研究评估原料药粒径分布、MCC/Lactose比例、崩解剂用量对制剂CQAs的影响。 第二处方研究用于理解颗粒外加硬脂酸镁和滑石粉对片剂质量和可生产…...

vulnyx Blogger writeup
信息收集 arp-scan nmap 获取userFlag 上web看看 一个默认的页面,gobuster扫一下目录 可以看到扫出的目录中得到了一个有价值的目录/wordpress,说明目标所使用的cms是wordpress,访问http://192.168.43.213/wordpress/然后查看源码能看到 这…...

push [特殊字符] present
push 🆚 present 前言present和dismiss特点代码演示 push和pop特点代码演示 前言 在 iOS 开发中,push 和 present 是两种不同的视图控制器切换方式,它们有着显著的区别。 present和dismiss 特点 在当前控制器上方新建视图层级需要手动调用…...

RabbitMQ入门4.1.0版本(基于java、SpringBoot操作)
RabbitMQ 一、RabbitMQ概述 RabbitMQ RabbitMQ最初由LShift和CohesiveFT于2007年开发,后来由Pivotal Software Inc.(现为VMware子公司)接管。RabbitMQ 是一个开源的消息代理和队列服务器,用 Erlang 语言编写。广泛应用于各种分布…...

Linux nano命令的基本使用
参考资料 GNU nanoを使いこなすnano基础 目录 一. 简介二. 文件打开2.1 普通方式打开文件2.2 只读方式打开文件 三. 文件查看3.1 打开文件时,显示行号3.2 翻页查看 四. 文件编辑4.1 Ctrl K 复制 和 Ctrl U 粘贴4.2 Alt/Esc U 撤回 五. 文件保存与退出5.1 Ctrl …...