(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

转载于:https://www.cnblogs.com/struggleli/p/6221575.html

String Start!相关推荐

  1. 【基础巩固篇】Java中String揭秘!

    作者:不清不慎,Java大数据开发工程师一枚,热爱研究开源技术! 架构师社区合伙人! String对象是我们日常使用的对象类型,字符串对象或者其等价对象(如char数组),在内存中总是占据了最大的空间 ...

  2. 面试: String 五连杀 !你还满血吗 ?

    点击上方蓝色"程序猿DD",选择"设为星标" 回复"资源"获取独家整理的学习资料! 作者 | Anthony_tester 来源 | blo ...

  3. String常用方法!

    字符串查找 String提供了两种查找字符串的方法,即indexOf与lastIndexOf方法. - 1.indexOf(String s) 该方法用于返回参数字符串s在指定字符串中首次出现的索引位 ...

  4. Swift 中 String 取下标及性能问题

    取下标 String String 用 String.Index 取下标(subscript)得到 Character,String.Index 要从 String 中获取 let greeting ...

  5. 面试:那些问哭你的Redis分布式锁!

    点击上方蓝色"程序猿DD",选择"设为星标" 回复"资源"获取独家整理的学习资料! 作者 | Vt 来源 | juejin.im/post/ ...

  6. String 字符串去除特殊字符和空格,正则表达式使用,%1$s

    特殊字符 String tt = "sdfdf{fwe }fwef< fwef #$";String regEx="[`~!@#$%^&*()+=|{}': ...

  7. ie9支持string.trim()

    忽然间发现 ie9支持string.trim()! 搞得我以为我写的代码是对的,结过在别的浏览器上一测就报错了.

  8. String与StringBuffer和StringBuilder的根本区别

    *************************************优雅的分割线 ********************************** 分享一波:程序员赚外快-必看的巅峰干货 如 ...

  9. html内容页上一页下一页,帝国CMS内容页增加内容分页上一页标签功能!

    帝国CMS一直以来升级没有提供内容分页的上一页标签功能,只有一个:内容页下一页[!--next.page--] 标签!所以下面就是要改造一下这个标签,实现内容页上一页的功能! 步骤如下: 打开e/cl ...

最新文章

  1. 数据分享 | LSTM神经网络架构和原理及其在Python中的预测应用(附视频)
  2. Centos下Yum安装PHP5.5,5.6
  3. Rabbitmq 极简实现
  4. el-amap 第一次正常第二次报错_flutter run: build tools revision 报错解决
  5. ASP.NET Core MVC with EF Core-迁移
  6. PHP企业级开发环境配置全攻略-IDE+SVN++(转)
  7. python中for循环-python中关于for循环的碎碎念
  8. Java_Date_01_判断两个时间相差的天数
  9. 1-springboot基础
  10. 用了10年海尔家电,青岛一音乐老师为海尔写了1首歌
  11. OpenSTA —— 高效的 web 性能测试工具
  12. 蓝牙路由器系列产品:企业级Cassia E1000
  13. win10 共享打印机错误0x00000709修复
  14. matlab泊松分布实现
  15. win7 oem key
  16. 不到一小时就可用Java做出坦克大战小游戏
  17. Python如何使用Any和All?代码示例和解析
  18. JavaScript工具函数
  19. oracle认证考试_通过获得Oracle助理认证来提升您的职业-PrepAway进行的1Z0-052考试复习
  20. Layer 打开新页面

热门文章

  1. openpyxl删除添加excel列_Python | 如何使用Python操作Excel(二)
  2. 计算机网络笔记----应用层
  3. 学习C ,常见的误解
  4. using用法是什么?
  5. C++定时器的实现之格式修订版
  6. C++ 异常的详细介绍
  7. pat 乙级 1002 写出这个数(C++)
  8. 【渝粤教育】 国家开放大学2020年春季 1039高级财务会计 参考试题
  9. 国家开放大学2021春1073法律文书答案
  10. 【渝粤题库】陕西师范大学200301几何学作业(高起本)