Leetcode PHP题解--D36 811. Subdomain Visit Count

栏目: PHP · 发布时间: 6年前

内容简介:题目给定一个字符串数组,每个字符串分两部分,以空格分割。第一部分为访问次数,第二部分为域名。

811. Subdomain Visit Count

题目链接

811. Subdomain Visit Count

题目分析

题目给定一个字符串数组,每个字符串分两部分,以空格分割。

第一部分为访问次数,第二部分为域名。

要求按同样的格式,分别返回顶级域名、二级域名、三级域名…的访问次数。

例如,字符串 "9001 discuss.leetcode.com"

discuss.leetcode.com 算一个域名;

leetcode.com 算另一个;

com 也是一个。

因此要返回 ["9001 discuss.leetcode.com", "9001 leetcode.com", "9001 com"]

思路

先把域名用 explode 函数拆分,再按层级把访问次数加到每个层级去。

最终代码

<?php
class Solution {
        function subdomainVisits($cpdomains) {
        $visits = [];
        foreach($cpdomains as $cpdomain){
            $item = explode(' ',$cpdomain);
            $domain = explode('.',$item[1]);
            $max = count($domain);
            for($i=$max-1; $i>=0;$i--){
                $d = implode('.', array_slice($domain, $i));
                if(!isset($visits[$d])){
                    $visits[$d] = 0;
                }
                $visits[$d] += $item[0];
            }
        }
        $v = [];
        foreach($visits as $domain => $visit){
            $v[] = $visit.' '.$domain;
        }
        return $v;
    }
}

若觉得本文章对你有用,欢迎用 爱发电 资助。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Clean Architecture

Clean Architecture

Robert C. Martin / Prentice Hall / 2017-9-20 / USD 34.99

Practical Software Architecture Solutions from the Legendary Robert C. Martin (“Uncle Bob”) By applying universal rules of software architecture, you can dramatically improve developer producti......一起来看看 《Clean Architecture》 这本书的介绍吧!

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

SHA 加密
SHA 加密

SHA 加密工具

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具