38. 报数

LeetCode 的算法题 PHP解法记录

报数序列是指一个整数序列,按照其中的整数的顺序进行报数,得到下一个数。其前五项如下:

  1. 1
  2. 11
  3. 21
  4. 1211
  5. 111221

1 被读作 "one 1" ("一个一") , 即 11。
11 被读作 "two 1s" ("两个一"), 即 21。
21 被读作 "one 2", "one 1" ("一个二" , "一个一") , 即 1211。

给定一个正整数 n ,输出报数序列的第 n 项。

注意:整数顺序将表示为一个字符串。

示例 1:

输入: 1
输出: "1"

示例 2:

输入: 4
输出: "1211"

解:

  function saynum($cou=1,$int='1'){
    $str0= $int;
    $len=strlen($str0);
$nums=1;
$number=null;
$res='';
    for($i=0;$i<$len;$i++){
        $number=$str0[$i];
        if($str0[$i] != @$str0[$i+1]){
            $res.=$nums.$number;
            $nums=1;
        }else{
            $nums++;
        }
    }
    if($cou > 1){
        $res = saynum($cou-1, $res);
    }
    return $res;
}

 $a= saynum(6);
 var_dump($a); //string(8) "13112221" 
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容