算法练习之报数, 最大子序和,最后一个单词的长度,加一,二进制求和

 1.报数

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

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(1 ≤ n ≤ 30),输出报数序列的第 n 项。

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

示例 1:
输入: 1
输出: "1"

示例 2:
输入: 4
输出: "1211"

java

class Solution {
    public String countAndSay(int n) {

        if(n==0) return "";
        if(n==1) return "1";
        String s = "1";
        for(int i=2;i<=n;i++){
            s=backStr(s);
        }
        return s;
    }
    public String backStr(String s){

        StringBuilder sb = new StringBuilder();
        char c = s.charAt(0);
        int count=1;
        int i=1;
        for(;i<s.length();i++){
            if(c==s.charAt(i)){
                count++;
            }else{
                sb.append(count).append(c);
                c = s.charAt(i);
                count=1;
            }
        }
        if(count>0){
            sb.append(count).append(c);
        }
        return sb.toString();
    }
}

php

class Solution {

    /**
     * @param Integer $n
     * @return String
     */
    public function countAndSay($n)
    {
        if ($n == 0)  return "";
        if ($n == 1)  return "1";
        $s = "1";
        for ($i = 2; $i <= $n; $i++) {
            $s = $this->backStr($s);
        }
        return $s;
    }
    public function backStr($s)
    {
        $rs = "";
        $k  = 1;
        $c = $s[0];
        for ($i = 1; $i < strlen($s); $i++) {
            if ($s[$i] == $c) {
                $k++;
            } else {
                $rs .= $k . $c;
                $c = $s[$i];
                $k = 1;
            }
        }
        if($k>0){
            $rs .= $k . $c;
        }
        return $rs;
    }
}

2.最大子序和

给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。

示例:

输入: [-2,1,-3,4,-1,2,1,-5,4],
输出: 6
解释: 连续子数组 [4,-1,2,1] 的和最大,为 6。

java

class Solution {
    public int maxSubArray(int[] nums) {
        
        int sum = 0;
        int rs = nums[0];
        for(int n:nums){
            if(sum>0){
                sum+=n;
            }else{
                sum = n;
            }
            rs = Math.max(rs,sum);
        }
        return rs;
    }
}

php

class Solution {

    /**
     * @param Integer[] $nums
     * @return Integer
     */
    function maxSubArray($nums) {
        
        $sum = 0;
        $rs = $nums[0];
        foreach ($nums as $key => $value) {
            if($sum>0){
                $sum+=$value;
            }else{
                $sum = $value;
            }
            $rs = max($rs,$sum);
        }
        return $rs;
    }
}

 3.最后一个单词的长度

给定一个仅包含大小写字母和空格 ' ' 的字符串,返回其最后一个单词的长度。

如果不存在最后一个单词,请返回 0 。

说明:一个单词是指由字母组成,但不包含任何空格的字符串。

示例:

输入: "Hello World"
输出: 5

java

class Solution {
    public int lengthOfLastWord(String s) {

        int len = 0;
        boolean isLetter = false;
        char[] arr = s.toCharArray();
        for(int i =arr.length-1;i>=0;i--){
            if(arr[i]==' '){
                if(!isLetter){
                    continue;
                }
                break;
            }else{
                isLetter = true;
                len++;
            }
        }
        return len;
    }
}

php

class Solution {

    /**
     * @param String $s
     * @return Integer
     */
    function lengthOfLastWord($s) {
        
        $len = 0;
        $s = rtrim($s);
        if(!empty($s)){
            for($i=strlen($s)-1;$i>=0;$i--){
                if($s[$i]!=' '){
                    $len++;
                }else{
                    break;
                }
            }
        }
        return $len;
    }
}

 4.加一

给定一个由整数组成的非空数组所表示的非负整数,在该数的基础上加一。

最高位数字存放在数组的首位, 数组中每个元素只存储一个数字。

可以假设除了整数 0 之外,这个整数不会以零开头。

示例 1:
输入: [1,2,3]
输出: [1,2,4]
解释: 输入数组表示数字 123。

示例 2:
输入: [4,3,2,1]
输出: [4,3,2,2]
解释: 输入数组表示数字 4321。

java

class Solution {
    public int[] plusOne(int[] digits) {
        int c=0;
        boolean f= false;
        for(int i=digits.length-1;i>=0;i--){
            if(digits[i]+1>9){
                f = true;
                digits[i] = 0;
            }else{
                digits[i] +=1;
                f=false;
                break;
            }
        }
        if(f) {
            digits = new int [digits.length + 1];
            digits[0] = 1;
        }
        return digits;
    }
}

php

class Solution {

    /**
     * @param Integer[] $digits
     * @return Integer[]
     */
    function plusOne($digits) {
        $f = false;
        for ($i = count($digits) - 1; $i >= 0; $i--) {
            if ($digits[$i] + 1 > 9) {
                $f          = true;
                $digits[$i] = 0;
            } else {
                $f = false;
                $digits[$i] += 1;
                break;
            }
        }
        if ($f) {
            array_unshift($digits, 1);
        }
        return $digits;
    }
}

5.二进制求和

给定两个二进制字符串,返回他们的和(用二进制表示)。

输入为非空字符串且只包含数字 1 和 0

示例 1:
输入: a = "11", b = "1"
输出: "100"

示例 2:
输入: a = "1010", b = "1011"
输出: "10101"

java

class Solution {
    public String addBinary(String a, String b) {
        String str = "";
        int r = 0, sum = 0;
        int p = a.length() - 1;
        int q = b.length() - 1;
        while (p>=0 ||q>=0) {
            int a1 = p >= 0 ? a.charAt(p--)-'0' : 0;
            int b1 = q >= 0 ? b.charAt(q--)-'0' : 0;
            sum = a1 + b1 + r;
            str = String.valueOf(sum % 2) + str;
            r = sum / 2;
        }
        if(r==1) str = "1"+str;
        return str;
    }
}

php

class Solution {

    /**
     * @param String $a
     * @param String $b
     * @return String
     */
    function addBinary($a, $b) {
        $p = strlen($a)-1;
        $q = strlen($b)-1;
        $r = 0;$sum = 0;
        $str = '';
        while($p>=0||$q>=0){
            $a1 = $p>=0?$a[$p--]:0;
            $b1 = $q>=0?$b[$q--]:0;
            $sum = $a1+$b1+$r;
            $str = ($sum%2).$str;
            $r = floor($sum/2);
        }
        if($r==1) $str = "1".$str;
        return $str;
    }
}

 

posted @ 2019-05-17 13:46  慕尘  阅读(291)  评论(0编辑  收藏  举报