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;
    }
}

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


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

查看所有标签

猜你喜欢:

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

程序员2005精华本

程序员2005精华本

《程序员》杂志社 / 电子工业 / 2006-1 / 45.00元

本书为集结了《程序员》杂志与《msdn开发精选》杂志精华。分上、下两册,内容包括人物&报道、管理与实践、程序员手册、年鉴、《程序员》技术专题、《msdn开发精选》文章精选等。一起来看看 《程序员2005精华本》 这本书的介绍吧!

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试

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

RGB CMYK 互转工具