当前位置: 首页 > news >正文

苏州住房和城乡建设厅网站太原做淘宝网站的

苏州住房和城乡建设厅网站,太原做淘宝网站的,潍坊网站建设方案,孟村网站建设价格今日学习的文章链接和视频链接 leetcode题目地址:459. 重复的子字符串 代码随想录题解地址:代码随想录 题目简介 给定一个非空的字符串 s ,检查是否可以通过由它的一个子串重复多次构成。 看到题目的第一想法(可以贴代码) 1.…

  今日学习的文章链接和视频链接

leetcode题目地址:459. 重复的子字符串

 代码随想录题解地址:代码随想录

题目简介

给定一个非空的字符串 s ,检查是否可以通过由它的一个子串重复多次构成。

看到题目的第一想法(可以贴代码)

1. 记录每一个子串(从0开始,由短到长递增),一一与原字符串进行比较。

        好繁琐,写了好久,主要是没想清楚用哪种数据结构,引发了很多小bug。

        最后写了一个最暴力的解法(利用String类的substring)。。实在想赶紧写出来。

public boolean repeatedSubstringPattern(String s) {String res = "";int end = 1;int len = s.length();boolean check = true;while (end < len ){res = s.substring(0, end);int rLen = res.length();for (int com = 0; com < len; com = com + rLen){if (com+rLen <= len){if (!s.substring(com, com+rLen).equals(res)) {check = false;break;}}else return false;}if(check) return true;else check = true;end++;}return false;
}

实现过程中遇到哪些困难

1. 主要是没想清楚用哪种数据结构,引发了很多小bug。

看完代码随想录之后的想法

【解题思路】1. 暴力解法;2.移动匹配;3.KMP解法(s+s - 最长 相等 前后缀)

【想法】牛

看完视频自己写的ACC:

// 使用库函数(代替KMP算法部分)
public boolean repeatedSubstringPattern(String s) {String res = s + s;res = res.substring(1, res.length()-1);if(res.indexOf(s) == -1) return false;return true;
}
// 完全套用KMP算法(未简化)
public void getNext(int[] next, String s){int j = -1;next[0] = j;for (int i = 1; i < s.length(); i++){while(j >= 0 && s.charAt(i) != s.charAt(j+1)) j = next[j];if (s.charAt(i) == s.charAt(j+1)) j++;next[i] = j;}
}
public boolean repeatedSubstringPattern(String s) {String res = s + s;res = res.substring(1, res.length()-1);int[] next = new int[s.length()];getNext(next, s);int j = -1;for (int i = 0; i < res.length(); i++){while(j >= 0 && res.charAt(i) != s.charAt(j+1)) j = next[j];if (res.charAt(i) == s.charAt(j+1)) j++;if (j == s.length()-1) return true;}return false;
}

视频标答:

// KMP算法灵活应用
public void getNext(int[] next, String s){int j = -1;next[0] = j;for (int i = 1; i < s.length(); i++){while(j >= 0 && s.charAt(i) != s.charAt(j+1)) j = next[j];if (s.charAt(i) == s.charAt(j+1)) j++;next[i] = j;}
}
public boolean repeatedSubstringPattern(String s) {int len = s.length();if (len <= 1) return false;int[] next = new int[len];getNext(next, s);if (next[len - 1] >= 0 && len % (len-(next[len - 1]+1)) == 0) return true;return false;
}

学习时长


今日收获

1. 更熟悉了KMP算法的应用(先编辑next()数组,再将字串与原串进行比较)。

2. int[]数组排序:        Arrays.sort(intarr);

利用stream获取int[]的最大/小值:        int max/min = Arrays.stream(intarr).max().getAsInt();

打印int[]数组:        System.out.print(Arrays.toString(intarr));

http://www.yayakq.cn/news/336096/

相关文章:

  • 如何向百度提交自己的网站校园网站建设实施方案
  • 商洛 网站建设跨境电商最火的产品
  • 企业平台网站建设方案加快政务网站群建设管理
  • 如何开发微信微网站页面紧急更新自动转跳直播
  • 深深圳市建设局网站网页设计个人实训报告
  • 物流那个网站做推广好wordpress企业主题下载地址
  • 装修公司网站dede模板做漫画网站的需求
  • 有专业做网站的吗网站公司网站建设流程王晴儿
  • 万江网站建设公司python 手机网站开发
  • 做百度手机网站关键词uniapp页面设计
  • 网站空间租用哪家好软件开发具体做什么
  • 如何做好网站建设前期网站规划一个完整网页的制作
  • jsp网站网站移动端推广
  • 网站做编辑器简单手机网站
  • 网站的互动下载百度软件
  • pc网站建设怎么弄网站建设明薇通网络价格美丽
  • js 取网站域名做企业网站需要准备什么
  • 惠州网站建设找哪个公司典型的o2o平台有哪些
  • 百度右边相关网站wordpress注册邮箱发送邮件
  • 盘石做的网站做网站的做网站麻烦吗
  • 国外电商网站如何建立网站后台 批量上传
  • 石家庄网站建设wsjzapp网站制作软件
  • 泰安网站制作排行户外拓展公司网站开发
  • 足球个人网站模板网站地图 格式
  • 电子商城网站建设的实训内容记述自建站平台
  • 网站新手引导怎么做陕西省建设协会岗位证查询网站
  • 本地网站建设公司邢台建站企业邮箱
  • 做的网站修改编码wordpress账号创建
  • 上海史特做网站多少钱做网站作业什么主题
  • 做一个公司网站的费用wordpress会员是主机么