Leetcode 467.环绕字符串中的唯一子字符串

环绕字符串中的唯一子字符串

把字符串 s 看作是"abcdefghijklmnopqrstuvwxyz"的无限环绕字符串,所以 s 看起来是这样的:"...zabcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyzabcd....".

现在我们有了另一个字符串 p 。你需要的是找出 s 中有多少个唯一的 p 的非空子串,尤其是当你的输入是字符串 p ,你需要输出字符串 s 中 p 的不同的非空子串的数目。

注意: p 仅由小写的英文字母组成,p 的大小可能超过 10000。

示例 1:

输入: "a"

输出: 1

解释: 字符串 S 中只有一个"a"子字符。

示例 2:

输入: "cac"

输出: 2

解释: 字符串 S 中的字符串"cac"只有两个子串"a"、"c"。.

示例 3:

输入: "zab"

输出: 6

解释: 在字符串 S 中有六个子串"z"、"a"、"b"、"za"、"ab"、"zab"。.

解题思想

这道题是说给了一个字符串P,需要从其中找到所有出现在S中的子串。

这里的S的子串是一个比较神奇的存在,起就是abcdedf..zabcde…这样无限迭代下去的一个串,也就是只要P的字符串一直递增就好(z->a进位)

所以解题方法也很直接:

找出以‘a-z‘每个字符结尾的情况下,最长的子串有多长,然后将其相加就可以

 1 public class Solution {
 2     /**
 3      * 其实就是找出P中有多少个子串,子串能够在abcdedf...zabcdefg...zab...这样的一个子串里面找到
 4      * 也就是递增的过程
 5      * 考虑为一个26进制的数的序列
 6      * 使用dp的方式,找到以某个字符结尾的最长的有多少种可能
 7      */
 8     public int findSubstringInWraproundString(String p){
 9         int p_int[] = new int[p.length()];
10         int count[] = new int[26];
11         for (int i = 0; i < p.length(); i++){
12             p_int[i] = p.charAt(i) - ‘a‘;
13         }
14         int res = 0;
15         int maxLen = 0;
16         for (int i = 0; i < p.length(); i++) {
17             if (i > 0 && (p_int[i - 1] + 1) % 26 == p_int[i]) {
18                 maxLen++;
19             } else {
20                 maxLen = 1;
21             }
22             count[p_int[i]] = Math.max(count[p_int[i]], maxLen);
23         }
24         for (int i = 0; i < 26; i++) res += count[i];
25         return res;
26     }
27 }

原文地址:https://www.cnblogs.com/kexinxin/p/10280228.html

时间: 2024-07-31 15:58:47

Leetcode 467.环绕字符串中的唯一子字符串的相关文章

输入一个字符串,输出该字符串中对称的子字符串的最大长度。

public class LongestSymmtricalLength2 { /* * Q75题目:输入一个字符串,输出该字符串中对称的子字符串的最大长度. * 比如输入字符串“google”,由于该字符串里最长的对称子字符串是“goog”,因此输出4. */ public static void main(String[] args) { String[] strs = { "a","google", "elgoog", "agol

java统计字符串中字符及子字符串个数

import java.util.Scanner;public class Counter { static Scanner scanner = new Scanner(System.in); public static void count(String s) { int low, upper, num, others; low = upper = num = others = 0; for (int i = 0; i < s.length(); i++) { if (Character.is

[LeetCode] Unique Substrings in Wraparound String 封装字符串中的独特子字符串

Consider the string s to be the infinite wraparound string of "abcdefghijklmnopqrstuvwxyz", so s will look like this: "...zabcdefghijklmnopqrstuvwxyzabcdefghijklmnopqrstuvwxyzabcd....". Now we have another string p. Your job is to find

467 Unique Substrings in Wraparound String 封装字符串中的独特子字符串

详见:https://leetcode.com/problems/unique-substrings-in-wraparound-string/description/ C++: class Solution { public: int findSubstringInWraproundString(string p) { vector<int> cnt(26, 0); int len = 0; for (int i = 0; i < p.size(); ++i) { if (i >

js 判断字符串中是否包含某个字符串(转载)

from : https://www.cnblogs.com/ooo0/p/7741651.html String对象的方法 方法一: indexOf()   (推荐) var str = "123"; console.log(str.indexOf("3") != -1 ); // true indexOf() 方法可返回某个指定的字符串值在字符串中首次出现的位置.如果要检索的字符串值没有出现,则该方法返回 -1. 方法二: search() var str =

Node.js之判断字符串中是否包含某个字符串

server.txt内容如下: 阿里云服务器 关于应用场景,就不多说了,字符串是不论是后端开发还是前端开发等,都是要经常打交道了. test.js(node.js代码,只要被本地装了node.js环境,直接可通过node test.js运行看效果): var fs = require("fs"); var result = fs.readFileSync("./server.txt"); console.log("result:"+result)

PHP判断字符串中是否包含指定字符串,支持中文哦

RT,随手写的 1 /** 2 * 判断字符串中是否包含指定字符串 3 * @var source 源字符串 4 * @var target 要判断的是否包含的字符串 5 * @return bool 6 */ 7 function hasstring($source,$target){ 8 preg_match_all("/$target/sim", $source, $strResult, PREG_PATTERN_ORDER); 9 return !empty($strResul

C# GetValueList 获得字符串中开始和结束字符串中间得值列表

/// <summary> /// 获得字符串中开始和结束字符串中间得值列表 /// </summary> /// <param name="styleContent">样式内容</param> /// <returns></returns> private MatchCollection GetValueList(string str, string s, string e) { return Regex.Mat

从一个字符串中提取一个子字符串

编写一个函数,它从一个字符串中提取一个子字符串.函数原型如下: int substr(char dst[], char src[],int start, int len) {} 目标是:从 src 数组起始位置向后偏移 start个字符的位置开始,最多复制 len 个非NUL 字符到 dst数组.在复制完毕之后, dst 数组必须以 NUL字节结尾.函数的返回值是存储于 dst 数组中的字符串的长度. #include<stdio.h> #include<stdlib.h> #de