华为od真题 找朋友

这是一个关于算法实现的问题,描述了一群小朋友按照身高排列,每个小朋友需要找到第一个比自己高的好朋友。输入包含小朋友的数量和他们的身高,输出是每个小朋友的好朋友的位置。程序通过遍历身高数组来找到每个小朋友的好朋友,并将结果存储在一个列表中,没有找到好朋友的位置用0填充。示例给出了两个小朋友的情况,输出为00。

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

# 100分题

# 1 找朋友

# N个小朋友站成一对,第i个小朋友的身高为height[i],第i个小朋友可以看到的第一个比自己

# 身高更高的小朋友j,那么j是i的好朋友(要求j>i)。 请重新生成一个列表,对应位置的输出是

# 每个小朋友的好朋友位置,如果没有看到好朋友,请在该位置用0代替

# 小朋友人数范围是【0, 40000】

# 输入描述:第一行输入N,表示有N个小朋友; 第二行输入N个小朋友的身高Height[i], 都是整数

# 输出描述: 输出N个小朋友的好朋友的位置

# 示例:

# 2

# 100 95

# 输出: 0 0

def solve(self, n, nums):

    n=int(input())

    height=list(int(input().split(" ")))

    ans=[0]*n

    for i in range(n):

        idx=0

        for j in range(i+1, n):

            if height[i]<height[j]:

                idx=j

                break

        ans[i]=idx;

    for i in range(len(ans)): 

        if i!=len(ans)-1:

            print(ans[i]+" ")

        else:

            print(arr[i])

### 华为OD模式下的真题资料及考内容 华为OD(Organization Development,组织发展)模式的考内容涵盖了多个技术领域和理论知识,旨在全面评估候选人的专业能力和综合素质。以下是对考内容及相关资料的详细说明: #### 一、考范围 华为OD的题目范围广泛,主要涉及以下几个方面[^1]: - **编程语言**:包括但不限于Java、Python、C++、JavaScript等主流编程语言。 - **算法与数据结构**:重点考察常见的排序算法、搜索算法、动态规划等。 - **系统设计**:测候选人对分布式系统、微服务架构的理解能力。 - **业务场景分析**:通过案例分析的方式,考察候选人解决实际问题的能力。 - **OD理论框架**:涵盖组织诊断、变革实施、领导力与团队建设等内容。 #### 二、卷类型 根据引用资料,华为OD卷分为A/B/C/D/E等多种类型,每种类型的难度和侧重点有所不同[^2]: - **A卷**:基础题为主,适合初学者或入门级考生。 - **B卷**:中等难度,涵盖更多复杂算法和数据结构问题。 - **C卷**:偏重于系统设计和架构分析。 - **D卷**:综合考察编程能力与业务理解能力。 - **E卷**:高难度,针对高级工程师或专家级人才。 #### 三、高频考点 以下是华为OD中的高频考点[^2]: 1. **字符串处理**:如字符串匹配、反转、去重等问题。 2. **数组操作**:包括查找、排序、合并等操作。 3. **链表**:单链表、双链表的基本操作及复杂问题求解。 4. **树与图**:二叉树遍历、最短路径算法等。 5. **动态规划**:背包问题、最长公共子序列等经典问题。 6. **多线程与并发**:考察候选人对并发控制的理解。 #### 四、备考策略 为了更好地应对华为OD,可以采取以下策略: 1. 熟悉常见算法与数据结构,并能够快速实现代码。 2. 多做历年真题,了解考形式和难度。 3. 学习华为OD相关的理论知识,提升综合素养。 4. 参与模拟考,锻炼时间管理和抗压能力。 #### 五、示例真题 以下是一个典型的华为OD真题及其解答: ```python # 示例题目:给定一个整数数组,找到两个数使得它们的和等于目标值。 def two_sum(nums, target): num_to_index = {} for i, num in enumerate(nums): complement = target - num if complement in num_to_index: return [num_to_index[complement], i] num_to_index[num] = i return [] # 测用例 nums = [2, 7, 11, 15] target = 9 print(two_sum(nums, target)) # 输出: [0, 1] ``` #### 六、相关学习资源 除了官方提供的资料外,还可以参考以下资源进行学习[^3]: - **HCIA-Cloud Service考内容**:虽然侧重于云计算领域,但部分内容与OD相关。 - **在线课程**:如Coursera、Udemy等平台上的算法与数据结构课程。 - **书籍推荐**:《算法导论》、《Effective Java》等经典书籍。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值