• String Start!


    (1)Ransom Note

    解题思路:

    题目叫做Ransom Note,勒索信。勒索信,为了不暴露字迹,就从杂志上搜索各个需要的字母,组成单词来表达的意思。这样来说,题目也就清晰了,判断杂志上的字是否能够组成勒索信需要的那些字符。 这里需要注意的就是杂志上的字符只能被使用一次,不过不用考虑大小写的问题。 有一种最简单的理解就是对于ransomNote里每个字符出现的次数必须小于或者等于该字符在magazine出现的次数。

    原理就是列出了magazine的字母表,然后算出了出现个数,然后遍历ransomNote,保证有足够的字母可用。

    代码如下:

     1 public class Solution {
     2     public boolean canConstruct(String ransomNote, String magazine) {
     3         int[] arr = new int[26];
     4         for (int i = 0; i < magazine.length(); i++) {
     5             arr[magazine.charAt(i) - 'a']++;
     6         }
     7         for (int i = 0; i < ransomNote.length(); i++) {
     8             if (-- arr[ransomNote.charAt(i) - 'a'] < 0) {
     9                 return false;
    10             }
    11         }
    12         return true;
    13     }
    14 }
    View Code

    (2)Repeated Substring Pattern

    解题思路:重复子串的长度必须是输入字符串长度的除数。从长度/ 2开始搜索str.length的所有可能除数,如果i是长度的除数,则重复从0到i该子串i次,如果重复的子串等于输入str返回true。

    代码如下:

     1 public class Solution {
     2     public boolean repeatedSubstringPattern(String str) {
     3         int sumStr = str.length();
     4         for  (int i = sumStr / 2; i >= 1; i--) {
     5             if (sumStr % i == 0) {
     6                 int num = sumStr / i;
     7                 StringBuffer sb = new StringBuffer();
     8                 String strx = str.substring(0, i); 
     9                 for (int j = 0; j < num; j++) {
    10                     sb.append(strx);
    11                 }
    12                 if (sb.toString().equals(str)) {
    13                     return true;
    14                 }
    15             }
    16         }
    17         return false;
    18     }
    19 }
    View Code

    (3)Number of Segments in a String

    解题思路:记录空格数量即可。i位置的字符不是空格,同时i的前一个字符是空格,或者i等于0 

    代码如下:

     1 public class Solution {
     2     public int countSegments(String s) {
     3         int res = 0;
     4         for (int i = 0; i < s.length(); i++) {
     5             if (s.charAt(i) != ' ' && (i == 0 || s.charAt(i - 1) == ' ')) {
     6                 res++;
     7             }
     8         }
     9         return res;
    10     }
    11 }
    View Code
  • 相关阅读:
    mysql总结1
    shell 获取结果中的第n列,第n行
    automake中Makefile.am和configure.ac的格式及编译过程
    安卓常见错误解决方案
    kotlin 委托
    Kotlin 对象表达式和对象声明
    Kotlin 枚举类
    angular js自定义service的简单示例
    用angular.element实现jquery的一些功能的简单示例
    js判断中出现两个!!是什么意思?
  • 原文地址:https://www.cnblogs.com/struggleli/p/6221575.html
Copyright © 2020-2023  润新知