[每日一题] 67. 二进制求和

链接:Leetcode 难度等级:Easy 给你两个二进制字符串,返回它们的和(用二进制表示)。 输入为 非空 字符串且只包含数字 1 和 0。 示例 1: 输入: a = "11", b = "1" 输出: "100" 示例 2: 输入: a = "1010", b = "1011" 输出: "10101" 思路:这里采用了模拟数字按位累加的做法,“逢二进一“。把累加的结果放到StringBuilder中,最后倒置一次(因为累加是从个位加起的)。 ps:这里有点坑的是一开始误以为kotlin的Char类型的toInt()(已被废弃,使用code属性替代)方法可以直接把字符转换为数字,其实这样直接转换得到的是该数字对应的ASCII码。需要先把Char转换为String再toInt()。 class Solution { fun addBinary(a: String,…

[每日一题] 66. 加一

链接:Leetcode 难度等级:Easy 给定一个由 整数 组成的 非空 数组所表示的非负整数,在该数的基础上加一。 最高位数字存放在数组的首位, 数组中每个元素只存储单个数字。 你可以假设除了整数 0 之外,这个整数不会以零开头。 示例 1: 输入:digits = [1,2,3] 输出:[1,2,4] 解释:输入数组表示数字 123。 示例 2: 输入:digits = [4,3,2,1] 输出:[4,3,2,2] 解释:输入数组表示数字 4321。 示例 3: 输入:digits…

[每日一题] 58. 最后一个单词的长度

链接:Leetcode 难度等级:Easy 给你一个字符串 s,由若干单词组成,单词前后用一些空格字符隔开。返回字符串中 最后一个 单词的长度。 单词 是指仅由字母组成、不包含任何空格字符的最大子字符串。 示例 1: 输入:s = "Hello World" 输出:5 解释:最后一个单词是“World”,长度为5。 示例 2: 输入:s = "   fly me   to   the moon  " 输出:4 解释:最后一个单词是“moon”,长度为4。 示例 3: 输入:s = "luffy is still joyboy" 输出:…

[每日一题] 53. 最大子数组和

链接:Leetcode 难度等级:Easy 给你一个整数数组 nums ,请你找出一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。 子数组 是数组中的一个连续部分。 示例 1: 输入:nums = [-2,1,-3,4,-1,2,1,-5,4] 输出:6 解释:连续子数组 [4,-1,2,1] 的和最大,为 6 。 示例 2: 输入:nums = [1] 输出:1 示例 3: 输入:nums = [5,4,-1,7,…