【华为OD】2024D卷——API集群负载统计

题目描述:

某个产品的RESTful API集合部署在服务器集群的多个节点上,近期对客户端访问日志进行了采集,需要统计各个API的访问频次,根据热点信息在服务器节点之间做负载均衡,现在需要实现热点信息统计查询功能。
RESTfulAPI的由多个层级构成,层级之间使用/连接,如/A/B/C/D这个地址,A属于第一级,B属于第二级,C属于第三级,D属于第四级。
现在负载均衡模块需要知道给定层级上某个名字出现的频次,未出现过用0次表示,实现这个功能。

输入描述:
第一行为N,表示访问历史日志的条数,0<N<=100。
接下来N行,每一行为一个RESTfulAPl的URL地址,约束地址中仅包含英文字母和连接符/,最大层级为10,每层级字符串最大长度为10。
最后一行为层级L和要查询的关键字。
输出描述:
输出给定层级上,关键字出现的频次,使用完全匹配方式(大小写敏感)。

示例1
输入:
5
/huawei/computing/no/one
/huawei/computing
/huawei
/huawei/cloud/no/one
/huawei/wireless/no/one
2 computing
输出: 
2
说明:
在第二层级上,computing出现了2次,因此输出2

解题思路:

1、解析URL地址:将每个URL地址按照/分割,得到各个层级的名字。

2、统计目标层级上的关键字频次:遍历所有日志记录,检查指定层级是否包含目标关键字,并统计出现的次数。

3、输出结果:输出统计结果,即给定层级上关键字出现的频次。


代码部分

def count_keyword_at_level(urls, level, keyword):
    count = 0
    for url in urls:
        # 移除空字符串,避免开头的 '/' 产生空字符串
        # parts = list(filter(None, url.split('/')))
        parts = url.split('/')
        parts = [part for part in parts if part]

        #检查URL是否右足够的层级
        if len(parts) >= level:
            #检查目标层级的关键字是否匹配
            if parts[level - 1] == keyword:
                count += 1
    return count

n = int(input())
urls = [input().strip() for _ in range(n)]
level, keyword = input().strip().split()
level_s = int(level)

result = count_keyword_at_level(urls, level_s, keyword)
print(result)

涉及知识点:字符串、列表


结语:越简单的题目解法应该越多,请路过大神留下新的思路供本小白学习一下,打开思路

  • 5
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
华为机试中的API集群负载统计JS可以使用以下代码来实现: ```javascript // 假设API集群服务器的IP地址存储在一个数组中 var serverIPs = ["192.168.1.1", "192.168.1.2", "192.168.1.3"]; // 创建一个对象来存储每个服务器的负载统计数据 var loadStatistic = {}; // 初始化每个服务器的负载为0 serverIPs.forEach(function(ip) { loadStatistic[ip] = 0; }); // 模拟获取每个服务器的负载数据 function getLoadData() { serverIPs.forEach(function(ip) { // 这里可以调用真实的API来获取负载数据 // 假设返回的负载数据存储在一个load变量中 var load = getLoadFromServer(ip); loadStatistic[ip] = load; }); } // 模拟发送负载数据到服务器 function sendLoadData() { serverIPs.forEach(function(ip) { // 这里可以调用真实的API负载数据发送到服务器 sendLoadToServer(ip, loadStatistic[ip]); }); } // 定时执行获取负载数据和发送负载数据的函数 setInterval(function() { getLoadData(); sendLoadData(); }, 5000); ``` 上述代码通过使用JavaScript来实现API集群负载统计。它假设API集群服务器的IP地址存储在一个数组中,并使用一个对象来存储每个服务器的负载统计数据。然后,通过`getLoadData`函数获取每个服务器的负载数据,将其存储在负载统计对象中。之后,通过`sendLoadData`函数将负载数据发送到服务器。 最后,使用`setInterval`函数定时执行获取负载数据和发送负载数据的函数,以便在需要时更新负载数据并将其发送到服务器。 请注意,上述代码只是一个简单的示例,尚未提供获取负载数据和发送负载数据的真实实现。实际实现中,您需要根据具体的情况调用真实的API来获取和发送负载数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值