【华为机试真题 Python】找数字

这篇博客介绍了华为机试的一道Python题目,要求找到二维数组中每个元素最近的相等值元素,输出横纵坐标差值的绝对值之和。如果不存在等值元素,则输出-1。博客提供了示例输入输出、题目描述和参考代码,旨在帮助读者理解和解题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

写在前面

题目描述

输入描述

输出描述

示例

机试介绍

参考代码

写在最后


写在前面

【华为机试真题Python】从入门到入职-真题列表导读

【华为机试真题Python】从入门到入职-真题列表导读

题目描述


给一个二维数组 nums ,对于每一个元素 nums[i] ,找出距离最近的且值相等的元素,输出横纵坐标差值的绝对值之和,如果没有等值元素,则输出 -1。

例如:
输入数组 nums 为

3
5
0 3 5 4 2
2 5 7 8 3
2 5 4 2 4


对于 num[0][0] = 0,不存在相等的值;
对于 num[0][1] = 3,存在一个相等的值,最近的坐标为 num[1][4],最小距离为 4;
对于 num[0][2] = 5,存在两个相等的值,最近的坐标为 num[1][1],故最小距离为 2;
对于 num[1][1] = 5,存在两个相等的值,最近的坐标为 num[2][1],故最小距离为 1。

故输出为

-1 4 &

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

forest_long

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值