zoukankan      html  css  js  c++  java
  • LeetCode 686. Repeated String Match

    Given two strings A and B, find the minimum number of times A has to be repeated such that B is a substring of it. If no such solution, return -1.

    For example, with A = "abcd" and B = "cdabcdab".

    Return 3, because by repeating A three times (“abcdabcdabcd”), B is a substring of it; and B is not a substring of A repeated two times ("abcdabcd").

    Note:
    The length of A and B will be between 1 and 10000.

    题意:给定两个字符串A、B,如果B是A重复数次组成的字符串的子串,返回重复次数;如果不是,返回-1.

    思路:

    定义一个新字符串str,在str里重复增加字符串A,直到大于等于字符串B的长度。如果str包含子串B,返回true;否则,str再增加一个字符串A,再判断是否包含子串B。对str再加一个A来处理:A= “abcd”,B= “dabcdabcda”这种情况,即当str的长度大于等于B后,最多再加一个字符串就可以判断重复字符串是否可以包含B。代码如下:

    public int repeatedStringMatch(String A, String B) {
            int count = 0;
            StringBuilder str = new StringBuilder();
            while (str.length() < B.length()) {
                str.append(A);
                count++;
            }
            if (str.toString().contains(B))
                return count;
            else if (str.append(A).toString().contains(B))
                return count + 1;
            else
                return -1;
        }
  • 相关阅读:
    关于Faster-RCNN训练细节
    tensorflow 使用tfrecords创建自己数据集
    深度学习(tensorflow) —— 自己数据集读取opencv
    Tensorflow常见函数case argmax equal
    pandas dataframe类型操作
    celery 启动命令
    pipenv 虚拟环境新玩法
    拉取远程分支
    odoo 开发 context 上下文的用法
    odoo 二次开发的方法
  • 原文地址:https://www.cnblogs.com/zeroingToOne/p/7850487.html
Copyright © 2011-2022 走看看