Java [leetcode 30]Substring with Concatenation of All Words
题目描述:
You are given a string, s, and a list of words, words, that are all of the same length. Find all starting indices of substring(s) in s that is a concatenation of each word in words exactly once and without any intervening characters.
For example, given:
s: "barfoothefoobarman"
words: ["foo", "bar"]
You should return the indices: [0,9].
(order does not matter).
解题思路:
首先设置一个HashMap,里面键值为单词,元素值为对应单词出现的次数,将其作为比较的模板。
我们首先在一个大的循环里面获得字符串的第一个位置开始的第一个单词,查看上述的模板Map中是否存在这个单词。如果不存在,那么外面的大循环直接后移一位,匹配下一个位置开始的单词。同时内嵌循环,用于逐个单词进行排查。如果查找是存在的,那么我们把这个单词加入到新的Map中,同时统计次数也需要递增。接下来查看这个新Map中的该单词出现的次数是否小于的个等于模板中该单词出现的次数,如果大于该次数,说明情况是不符合要求的,跳出该内层循环,外层循环的指针后移。
最后如果内层循环如果顺利走完,则说明从该位置开始所有的单词都是匹配的,那么将该位置添加到List中,否则外层循环指针指向下一个字符的外置,继续开始类似的判断。
代码如下:
public class Solution {
    public List<Integer> findSubstring(String s, String[] words) {
		List<Integer> list = new ArrayList<Integer>();
		Map<String, Integer> map = new HashMap<String, Integer>();
		Map<String, Integer> tmp = new HashMap<String, Integer>();
		int sLength = s.length();
		int wordsNum = words.length;
		int wordsLength = words[0].length();
		int j;
		if (sLength < wordsNum || wordsNum == 0)
			return list;
		for (int i = 0; i < wordsNum; i++) {
			if (map.containsKey(words[i]))
				map.put(words[i], map.get(words[i]) + 1);
			else
				map.put(words[i], 1);
		}
		for (int i = 0; i <= sLength - wordsNum * wordsLength; i++) {
			tmp.clear();
			for (j = 0; j < wordsNum; j++) {
				String word = s.substring(i + j * wordsLength, i + j
						* wordsLength + wordsLength);
				if (!map.containsKey(word))
					break;
				if (tmp.containsKey(word))
					tmp.put(word, tmp.get(word) + 1);
				else
					tmp.put(word, 1);
				if (tmp.get(word) > map.get(word))
					break;
			}
			if (j == wordsNum)
				list.add(i);
		}
		return list;
	}
}
Java [leetcode 30]Substring with Concatenation of All Words的更多相关文章
- LeetCode - 30. Substring with Concatenation of All Words
		30. Substring with Concatenation of All Words Problem's Link --------------------------------------- ... 
- [LeetCode] 30. Substring with Concatenation of All Words 解题思路 - Java
		You are given a string, s, and a list of words, words, that are all of the same length. Find all sta ... 
- leetCode 30.Substring with Concatenation of All Words (words中全部子串相连) 解题思路和方法
		Substring with Concatenation of All Words You are given a string, s, and a list of words, words, tha ... 
- [LeetCode] 30. Substring with Concatenation of All Words 串联所有单词的子串
		You are given a string, s, and a list of words, words, that are all of the same length. Find all sta ... 
- LeetCode 30 Substring with Concatenation of All Words(确定包含所有子串的起始下标)
		题目链接: https://leetcode.com/problems/substring-with-concatenation-of-all-words/?tab=Description 在字符 ... 
- [leetcode]30. Substring with Concatenation of All Words由所有单词连成的子串
		You are given a string, s, and a list of words, words, that are all of the same length. Find all sta ... 
- [LeetCode] 30. Substring with Concatenation of All Words ☆☆☆
		You are given a string, s, and a list of words, words, that are all of the same length. Find all sta ... 
- [Leetcode][Python]30: Substring with Concatenation of All Words
		# -*- coding: utf8 -*-'''__author__ = 'dabay.wang@gmail.com' 30: Substring with Concatenation of All ... 
- LeetCode HashTable 30 Substring with Concatenation of All Words
		You are given a string, s, and a list of words, words, that are all of the same length. Find all sta ... 
随机推荐
- Django 下static的配置
			1.添加一个BASE_DIR在setting.py中,如果已存在可不用添加,需引入 import os BASE_DIR = os.path.dirname(os.path.dirname(os.pa ... 
- Oracle数据库间的数据复制 - SQLPlus中的COPY命令
			Copy命令可以实现不同Oracle数据库间的数据的复制,也是可以实现同一数据库的数据复制,其性能表现和导入/导出相同. 根据9i文档,说Copy命令未来会不支持,但实际上Oracle 11g仍然支持 ... 
- 【maven项目结构】module  生成独立的jar
			生成jar 生成jar的过程会出现以下问题: clean完了之后就会出现以下问题: install [INFO] Scanning for projects... [INFO] [INFO] ---- ... 
- 100 doors
			Question There are 100 doors in a row that are all initially closed. You make 100 passes by the door ... 
- Javascript字典操作
			<script type="text/javascript"> var dic = new Array(); //注意它的类型是Array ... 
- 酷摄影:关于梦 - Miki takahashi
			这组摄影来自于日本东京摄影师 Miki takahashi 是一组双重曝光摄影,分开看也许很平常,但是结合在一起却非常有韵味. [gallery] 
- 安装ADT Cannot complete the install because one or more required items could not be found.
			点击进行安装,将会弹出 错误提示是: Cannot complete the install because one or more required items could not be found ... 
- Notifications Nagios
			Introduction I've had a lot of questions as to exactly how notifications work. This will attempt to ... 
- ASP.NET树形控件TreeView的递归绑定
			来自:http://blog.csdn.net/xqf003/article/details/4958727 
- 《RabbitMQ in action》
			Producers create messages and publish (send) them to a broker server (RabbitMQ).What’s a message? A ... 
