2023华为od机试C卷【最富裕的小家庭】Python实现

在这里插入图片描述

思路:

在这里插入图片描述

def main():
    Num = int(input())#获取成员数
    
    #获取金钱列表,为了1对应100,我们添加一个索引为0对应的值为0
    Moneys = list(map(int,input().split()))#获取金钱输入
    Moneys.insert(0,0)

    #成员-金钱映射
    relationship = {}
    for i in range(1,Num+1):
        relationship[i] = Moneys[i]
    
    #金钱累积
    for _ in range(1,Num):#输入N-1行,所以右边界为Num就行
        a,b = map(int,input().split())
        relationship[a] += Moneys[b]
    
    #获取最大小家庭财富值
    Max_value = max(relationship.values())
    print(Max_value)

if __name__  ==  "__main__":
    main()

代码解释:

  1. 获取成员数

    Num = int(input())  # 获取成员数
    

    这行代码读取输入,获取成员的数量,并将其转换为整数。

  2. 获取金钱列表

    Moneys = list(map(int, input().split()))  # 获取金钱输入
    Moneys.insert(0, 0)  # 在列表首添加一个0
    

    这里读取一行输入,获取每个成员的金钱。通过 maplist 将输入转换为一个整数列表。由于成员的编号从1开始,使用 insert(0, 0) 在列表前添加一个值为0,以便于后续操作(使得 Moneys[i] 对应成员 i 的金钱)。

  3. 成员-金钱映射

    relationship = {}
    for i in range(1, Num + 1):
        relationship[i] = Moneys[i]  # 将每个成员的金钱映射到字典中
    

    初始化一个字典 relationship,将每个成员的编号映射到他们对应的金钱值。

  4. 金钱累积

    for _ in range(1, Num):  # 输入N-1行
        a, b = map(int, input().split())  # 读取每对关系
        relationship[a] += Moneys[b]  # 将b的金钱累加到a上
    

    这部分读取N-1行输入,每行包含两个数字 ab,表示 a 和 b 的关系。然后,将成员 b 的金钱值累加到成员 a 的金钱上,以记录他们之间的财务关系。

  5. 获取最大小家庭财富值

    Max_value = max(relationship.values())  # 找到关系中的最大值
    print(Max_value)  # 输出最大值
    

    使用 max 函数获取字典中金钱值的最大值,即最富有的成员的财富。

  6. 主函数调用

    if __name__ == "__main__":
        main()  # 调用主函数
    

    检查模块是否是主程序,如果是,则执行 main() 函数。

总结:

这段代码的主要功能是读取一组成员及其金钱输入,并根据支持的关系进行金钱累积,最后找出最富有成员的财富。通过这种方式,可以在一定的关系网络中分析成员的金钱分布情况。

题目要求编写一个函数,对于给定的字符串s,将相邻重复的字符用它们的个数和字符本身表示。 例如,给定字符串s = "aaabbbccc",函数应该返回字符串"3a3b3c"。 要解决这个问题,我们可以使用两个指针来遍历字符串。一个指针指向当前字符,另一个指针用来记录重复字符的个数。当遇到不同的字符或遍历到字符串末尾时,将重复字符的个数和字符本身添加到结果字符串中。 具体步骤如下: 1. 初始化一个空字符串result,用来存放结果。 2. 设置两个指针,一个指向当前字符指针cur,一个用来记录重复字符的指针count,初始值为1。 3. 从第二个字符开始,遍历整个字符串。 4. 如果当前字符等于前一个字符,则将count加1。 5. 如果当前字符不等于前一个字符,则将重复字符的个数count和前一个字符添加到result中,并将count重置为1。 6. 遍历结束后,将最后一个字符和重复字符的个数count添加到result中。 7. 返回结果字符串result。 以下是具体的实现代码: ```python def enhance_string(s): result = "" cur = 0 count = 1 for i in range(1, len(s)): if s[i] == s[cur]: count += 1 else: result += str(count) + s[cur] cur = i count = 1 result += str(count) + s[cur] return result ``` 测试样例: ```python s = "aaabbbccc" print(enhance_string(s)) # 输出"3a3b3c" ``` 通过以上步骤,我们可以成功地将字符串中的相邻重复字符替换为它们的个数和字符本身。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值