华为OD机试真题C卷-篇3

查找一个有向网络的头节点和尾节点

  • 在一个有向图中,有向边用两个整数表示,第一个整数表示起始节点,第二个整数表示终止节点;
  • 图中只有一个头节点,一个或者多个尾节点;
  • 图可能存在环,有环则输出-1;
  • 输出图中的头节点(入度为0)、尾节点(出度为0),如图头节点为1,尾节点为4。
    在这里插入图片描述
    输入描述:
    第一行输入n,n >=0
    第二行为n个数对,表示n条边;
    输出描述:
    输出一行,头节点、尾节点以空格隔开,多个尾节点则从大到小输出。
     
    示例1
    输入:
    4
    1 2 1 3 2 4 3 4
    输出:
    1 4

思路:

  • 拓扑排序,判断有向图是否有环,有环则直接输出-1;
  • 只有一个起始点,一个或多个结尾点;
relations = {
   }
indegree = {
   }
head = -1
tails = []
 
def find_head():
    global relations,indegree,head
    for  keys in relations:
        if (keys in indegree) :
            continue
        else :
            head = keys
            break
 
def find_tails():
    global relations,indegree,tails
    for keys in indegree :
        if (keys in relations) :
            continue
        else :
            tails.append(keys)
 
n = int(input())
nums = [int(x) for x in input().split(" ")]
        
i=0
while(i < 2 * n):
    if(nums[i] in relations):
        relations[nums[i]].append(nums[i + 1])
    else :
        relations[nums[i]] = []
        relations[nums[i]].append(nums[i + 1])
    
 
    if(nums[i + 1] in indegree):
        indegree[nums[i + 1]] += 1
    else :
        indegree[nums[i + 1]] = 1
    i += 2
    
 
find_head()
find_tails()
tails.sort()
 
queue = []
queue.append(head)
while (True) :
    if(len(queue)<=0):
        break
    else :
        temp = queue[0]
        queue.pop(0)
        if(temp in relations):
            temp_list = relations[temp]
            for  x in temp_list:
                indegree[x]= indegree[x] - 1
                if (indegree[x] == 0) :
                    queue.append(x)
flag = 1
for key in indegree:
    
    if (indegree[key] > 0) :
        flag = 0
 
if (flag==0) :
    print(-1)
else: 
    output_str = str(head) + " "
    for x in tails:
        output_str += str(x) + " "
 
    print(output_str[:-1])

 

幼儿园篮球游戏

在这里插入图片描述
在这里插入图片描述
双指针+ 线性表

import functools
import sys
import copy
import re
import math
 
nums = [int(x) for x in input().split(",")]
target_nums = [int(x) for x in input().split(",")]
 
arr = [float('inf') for i in range(300)]
 
left = 0
right = 0
target_pos = 0
 
result = ""
i=0
while(True):
    if(i>=len(nums)):
        break
    else :
        arr[right] = nums[i]
        right+=1
        while (True) :
            if(right <= left):
                break
            else :
                if (arr[left] == target_nums[target_pos]) :
                  result += "L"
                  left += 1
                  target_pos += 1
                  continue
                elif (arr[right-1] == target_nums[target_pos]) :
                  result += "R"
                  right -= 1
                  target_pos += 1
                  continue
                 
                break
    i+=1
 
if (left != right) :
  print("NO")
else :
  print(result)
 

相关推荐

  1. 2024华为OD-机场航班调度-C++(CD)

    2024-02-07 06:00:04       10 阅读
  2. 2024华为OD-出租车计费-C++(CD)

    2024-02-07 06:00:04       9 阅读
  3. 华为OD-攀登者1-2023年OD统一考试(C

    2024-02-07 06:00:04       49 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-02-07 06:00:04       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-02-07 06:00:04       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-02-07 06:00:04       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-02-07 06:00:04       18 阅读

热门阅读

  1. 计算机网络(第六版)复习提纲26

    2024-02-07 06:00:04       26 阅读
  2. 如何为Kafka加上账号密码(一)

    2024-02-07 06:00:04       26 阅读
  3. window开机启动

    2024-02-07 06:00:04       31 阅读
  4. 【Flink】FlinkSQL实现数据从Kafka到MySQL

    2024-02-07 06:00:04       29 阅读
  5. 2.6作业

    2024-02-07 06:00:04       27 阅读
  6. 安装nodejs2011并配置npm仓库

    2024-02-07 06:00:04       33 阅读
  7. VOL_常用记录!!

    2024-02-07 06:00:04       30 阅读
  8. 嵌入式硬件工程师与嵌入式软件工程师

    2024-02-07 06:00:04       41 阅读