华为笔试AC的两道(第三道不会,我太菜)

article/2025/10/11 4:31:45

1、猪场防疫

      老李在多年前承包了一个养猪场, 并引入了若干只种猪,经过这些年的经营,现在养猪场有N只猪,编号从0到N-1 (每只猪无论生死都有唯一的编号) ;

      老李在每只猪生产的时候记下了生产的母猪和出生的小猪,格式: x y1 y2 …(注: x为猪妈妈,y1、 y2、 …为新生的猪崽,以上编码均在0…N-1内,每只猪可以多次生产,每个猪崽只有一个猪妈妈) ;

      为了防疫需要,要检查任意两只猪是否有亲戚关系(两只猪具有相同的祖先),并计算出关系亲疏情况(关系距离,相同编号距离为0)。

输入
第一行猪总数N
第二行记录数M
后续M行记录,空格分割
x y1 y2 …

最后一行 两个编号 m1 和m2 表示待检查的两只猪的编号

思路: 这题一看就差不多能想到并查集,如果不是求距离而是求是否有亲戚关系(有共同祖先),那就是标准的并查集模板,但是加了求距离,并查集就不是很好做。所以我们呢换个思路

      我们可以简单的想象出来 m1 一直往上溯源,是形成一条链是吧(类似高中生物的遗传图谱),那就意味着每个个体溯源到最初祖先 都是一条链表。换句话说,题目就是让我们求两条链表中相同数字出现的最早位置(就是最近公共祖先了),但是由于我用python写嘛,所以用数组,直接用index函数求下标了,所以用了数组来模拟。同时我俩简化判断一个属在不在另一条链中(数组),所以用到了set 加快速度

n = int(input())
m = int(input())
num_dict = dict()
for i in range(m):  # 构建每只猪的父节点 dict ,处理输入arr = list(map(int,input().split(" ")))for i in range(1,len(arr)):num_dict[arr[i]] = arr[0]m1,m2 = list(map(int,input().split(" ")))# 构建两个数组(其实就是两条链辣)
arr1 = [m1]
while m1 in num_dict.keys():arr1.append(num_dict[m1])m1 = num_dict[m1]arr2 = [m2]
while m2 in num_dict.keys():arr2.append(num_dict[m2])m2 = num_dict[m2]set1 = set(arr1)  # 便于后续检查
ans = -1
for i in range(len(arr2)):if arr2[i] not in set1:  # 判断当前编号是否也在arr1中出现了continueelse:ans = i + arr1.index(arr2[i])break
print(ans)

测试用例1

输入 :
3
1
0 1 2
0 1
输出:
1
解释:0-1 是亲戚关系,距离是1

测试用例1

输入 :
5
2
0 1 2
1 3 4
2 4
输出:
3
解释:2-0-1-4 是亲戚关系,距离是3

2、速战速决

      在一个MxN的街区中,有一个士兵S和一个敌人E, 标识X为无法通过的街区,标识B为可以通过的街区;士兵在一个单位时间内可以从一个街区移动到相邻的街区(土兵每次只能水平或者垂直方向移动一个街区) ;士兵每次改变方向时,需要额外花费个 单位的时间(士兵第一次移动个街区的时候,不用考虑其初始方向,即只需要一个单位时间即可到达相邻街区)。计算士兵S最少需要多少时间才能到达E所在的街区。

输入

第一行为两个数字,表示街区的大小,M行,N列; (1 <= M.N<=1000,M、N不同时为1)

接下来M行,每行N个字母,字母S表示士兵所在街区,字母E表示敌人所在街区,字母X表示障碍,字母B表示可以经过的街区。(只有1个S,一个E)

输出

最少需要的时间,当士兵S永远无法到达敌人E所在的街区时,输出-1

思路:其实很简单 就是二维数组两点最短路径 一般用bfs最好,但是由于题目加了限制,换向时要罚一单位时间,所以只能用dfs,记录一个方向信息即可,方向信息也简单,在dfs中一般有一个数组来充当上下左右嘛。数组下标和方向时一一对应的,所以直接使用来判断就行

m,n = list(map(int,input().split(" ")))
arr = []
startx,starty,endx,endy = -1,-1,-1,-1
for i in range(m):temp = list(input())arr.append(temp)if "S" in temp:startx = istarty = temp.index("S")if "E" in temp:endx = iendy = temp.index("E")class solution2:def help(self,arr,startx,starty,endx,endy,m,n):if startx == -1 or endx == -1 or starty==-1 or endy ==-1:return -1self.ans = 999999self.visit = set()self.arr = arrself.endx= endxself.endy = endyself.m = mself.n = nself.DFS(startx, starty, -1, -1)def DFS(self,x, y, length, direction):if x == self.endx and y == self.endy:self.ans = min(length,self.ans)print(length,self.ans)returnself.visit.add((x, y))  # 这个点探索过了nextarr = [[0, 1], [0, -1], [-1, 0], [1, 0]]  # 上下左右for i in range(4):tx = x + nextarr[i][0]ty = y + nextarr[i][1]if tx < 0 or ty < 0 or tx >= self.m or ty >= self.n:continueif self.arr[tx][ty] == "X" or (tx, ty) in self.visit:continueself.DFS(tx, ty, length + 1 + int(i != direction), i)solu = solution2()
solu.help(arr,startx,starty,endx,endy,m,n)
if 999999==solu.ans:print(-1)
else:print(solu.ans)

测试用例

在这里插入图片描述

在这里插入图片描述


http://chatgpt.dhexx.cn/article/hwVNGrHo.shtml

相关文章

2021-07-08 华为2022批笔试

华为2022批笔试 三道题T1T2T3 三道题 总结&#xff1a;写的时候太紧张了&#xff0c;很烦 T1 题目&#xff1a;给出n个任务的最晚完成时间&#xff08;单位为小时&#xff09;和对应积分&#xff0c;每小时只能做一个任务&#xff0c;且超时后不获得积分&#xff0c;求出最大…

2017华为笔试、面试经历

**背景介绍**&#xff1a;2016年7月参加第十一届“华为杯”研究所电子设计大赛获西北赛区一等奖&#xff0c;于2016年8月到上海嘉定工业区参加全国总决赛获全国三等奖。 期间&#xff0c;参加了在线测评、笔试、专业面试、综合面试、部门选择、未完待续。 **备注**&#xff1a;…

4.15日华为笔试

参考&#xff1a; 华为笔试&#xff0c;大家做的怎么样&#xff1f;华为4.15笔试前两题AC - 正则表达式华为笔试2.7 4-15 - C华为4.15笔试 - C 题目简介&#xff1a; 第一题&#xff1a;求获胜者&#xff0c;如果票数相当&#xff0c;按照字母排序&#xff0c;a>b>c,A…

19.华为笔试题整理

1.两数之和 数组可以有重复元素,所以与力扣的第一题稍微有点不同 public int[] twoSum(int[] numbers, int target) {int n numbers.length;HashMap<Integer, Integer> map new HashMap<>();for (int i 0; i < n; i) {int realTarget target - numbers[i];i…

华为2020校招笔试编程题

华为2020校招笔试编程题 刚做完华为的笔试题&#xff0c;简要描述一下三道编程题的解决方法以及python代码实现 第一题大致描述&#xff1a; 给定两个已经升序排序好的的序列A{a1,a2,a3,...an} 和B{b1,b2,b3...bn} &#xff0c;一个数R&#xff0c;找出满足以下条件的的&#x…

华为笔试题 2022.3.30

1、业务部署芯片 思路&#xff0c;就硬模拟 #include <algorithm> #include <iostream> #include <string> #include <vector>using namespace std;int main() {int m, n;cin >> m;cin >> n;char arr[n];for (int i 0; i < n; i) {ci…

华为2019届校招笔试题

1. 给出一个字符串&#xff0c;将重复的字符去除&#xff0c;仅保留第一次出现的字符&#xff0c;且保持去重后的字符在原字符串中的顺序不变。 输入数据是一个字符串&#xff08;不包含空格&#xff09; 输出去重后的字符串 输入&#xff1a;12ere2 输出&#xff1a;12er…

【JAVA】【华为校园招聘笔试-软件】2020-09-09

前言 华为三道题&#xff0c;100200300&#xff0c;100及格&#xff0c;大家做对第一题就好了&#xff0c;祝大家全都有心仪的offer&#xff0c;不要慌&#xff0c;不要焦虑 一、完美排列——玩具&#xff08;全A&#xff09;&#xff08;注意&#xff1a;题目中说&#xff…

华为2020届逻辑笔试

1、十进制46.25对应的二进制表达式为( )。 A 101110.11 B 101101.01 C 101110.1 D 101110.01 解析&#xff1a; 首先这个题目是由整数部分和小数不同共同组成的&#xff0c;整数部分的计算是最简单的&#xff0c;整数部分除以2得到的余数按照逆向顺序排列后就是整数部分转化为二…

华为笔试

目录 2017年4月21日华为笔试题 圣诞的祝福 2017年4月21日华为笔试题 德州扑克 2017年4月21日华为笔试题 日期的天数序号 2017华为笔试题 任务调度 2017华为笔试题 公司年会 2017华为笔试题 水仙花数 2018华为笔试题 2018华为笔试题2 2017年4月21日华为笔试题 圣诞的祝福…

1.华为实习笔试

第一题(100分) 版本号排序问题,比如1.1.1版本大于1.0.0版本,每个.分割的数字范围是0-256,可以省略,比如..等价于0.0.0,可以有前导0,比如001.001.1等价于1.1.1;程序输入:需要排序的版本号个数,和各个版本号字符串,输出排序后的结果 public static List<String> dealSpli…

find命令用法

一.简介 linux的find命令用于查找指定目录中符合参数条件的文件&#xff0c;如果不设置任何参数&#xff0c;则find命令将在当前路径下查找子目录与文件。并且将查到的子目录和文件全部显示。 二.find命令常用参数 1&#xff09;根据文件名及文件拥有人拥有组查找文件 环境…

Linux下find命令详解

Linux下find命令详解 find命令格式find命令的参数find的常规用法1、按名字查找2、按目录查找3、按权限查找4、按类型查找  &#xff08;b/d/c/p/l/f &#xff09;5、按属主及属组6、按时间查找7、按文件新旧8、按大小查找9、执行命令关于 有没有 -print 的区别 find命令格式 …

java find()_java 之 find 命令

转自&#xff1a;https://blog.csdn.net/holyshit666/article/details/52296966 find命令是比较常用的命令&#xff0c;用来在特定目录下查找具有某种特征的文件。 一&#xff1a;find命令格式如下&#xff1a; find [-path......] -options [-print -exec -ok] path:要查找的目…

find 命令常用用法

find 命令——文件或目录查找而且可以直接对查找结果使用命令。 find 查找范围 查找条件 -name 按名称查找 -maxdepth 查看多深的文件&#xff0c;不能超过所限制的目录下的内容 -mindepth 查看不小于多深的文件&#xff0c;不低于所限制内容…

文件查找find命令

#!/bin/bash find /etc -name *.conf find /etc -iname "aa" #不区分大小写 find . -user hdfs find . -group yarn find /etc -type f #文件 find /etc -type d #路径 find /etc -size 1M #文件大小大于1M find /etc -size -100k #文件大小小…

Linux find命令详解

基础打印操作 find命令默认接的命令是-print&#xff0c;它默认以\n将找到的文件分隔。可以使用-print0来使用\0分隔&#xff0c;这样就不会分行了。但是一定要注意&#xff0c;-print0针对的是\n转\0&#xff0c;如果查找的文件名本身就含有空格&#xff0c;则find后-print0仍…

Linux 的find命令用法

摘要 find 是Unix/Linux命令行工具箱中最棒的工具之一。该命令在命令行和shell脚本编写方面都 能发挥功效。find 包含大量特性&#xff0c;本文记录find 的一些常用的查找功能。 find 命令的工作方式如下&#xff1a;沿着文件层次结构向下遍历&#xff0c;匹配符合条件的文件&…

linux find命令格式及find命令详解

本文详细介绍了linux find命令格式及find命令案例&#xff0c;希望对您的学习有所帮助。1、find命令的一般形式为&#xff1b; find pathname -options [-print -exec -ok ...]2、find命令的参数&#xff1b; pathname: find命令所查找的目录路径。例如用.来表示当前目录&#…

Windows命令之find命令

一、命令简介 find 命令用于查找文档中的特定字符和数字及行号, 好比, 我们在阅读文档时, 使用的快捷键 Ctrl F 来查找是一个效果, 经过 find 查找的字符也可以重定向到一个文本文档里面去, 提取特定的字符, 来进行文档的整合。 二、使用示例 1、获取命令帮助 使用 find /?…