zoukankan      html  css  js  c++  java
  • 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
  • 相关阅读:
    Linux基本命令(一)
    Linux基本命令(一)
    前端js实现打印excel表格
    前端js实现打印excel表格
    前端js实现打印excel表格
    前端js实现打印(导出)excel表格
    前端js实现打印(导出)excel表格
    混合开发中拍照和打电话功能的代码
    混合开发中拍照和打电话功能的代码
    操作系统的发展史(科普章节)
  • 原文地址:https://www.cnblogs.com/struggleli/p/6221575.html
Copyright © 2011-2022 走看看