<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
解題思路已經寫在程式碼中了;
class Solution { public: bool contain(string &a, string &b, long long hash_b) { for (int i = 0; i <= a.size() - b.size(); i++) { int k = 0; long long hash_a = 0; while (k < b.size()) { hash_a = (hash_a * 26 + a[i + k] - 'a') % INT32_MAX; k++; } if (hash_b == hash_a) return true; } return false; } int repeatedStringMatch(string a, string b) { // 1、統計a每個字元出現次數、b每個字元出現次數,如果b有某字元而a沒有,返回-1 vector<int> rec_a(30, 0); vector<int> rec_b(30, 0); for (char c : a) { rec_a[c - 'a']++; } long long hash_b = 0; int i = 0; for (char c : b) { hash_b = (hash_b * 26 + c - 'a') % INT32_MAX; rec_b[c - 'a']++; } for (int i = 0; i < 30; i++) { if (rec_b[i] > 0 && rec_a[i] == 0) { return -1; } } // 2.1 本身b就是a的字串,用hash if (a.size() >= b.size() && contain(a, b, hash_b)) { return 1; } // 2.2 最大重疊不超過Bsize/Asize + 2 string aa = a; for (int i = 2; i <= b.size() / a.size() + 2; i++) { aa += a; if (aa.size() < b.size()) continue; if (contain(aa, b, hash_b)) { return i; } } return -1; } };
但是C++畢竟沒有類似Java的contains函數,所以檢查a字串是否包含b就沒有那麼方便,我這裡自己實現的是利用hash來檢測,其實可以優化一下:
(當前hash值-(當前視窗首字元-'a')*26^k)*26 + 視窗右移新加進來的字元-'a'
;於是對 Java String 裡面的 contains 函數很好奇,它內部怎麼實現的,就翻了下原始碼,如下:
// String.contails(String s): // 返回this字串是否包含 子串s public boolean contains(CharSequence s) { return this.indexOf(s.toString()) >= 0; }
// String.indexOf(String s) // 返回this字串中子串s的首字元索引 ........ // 中間的幾個函數就省略了,都是一些特殊情況(比如this字串的長度小於s字串的長度,直接返回-1這種), // 最後實現是在這個函數裡 public static int indexOfLatin1Unsafe(byte[] src, int srcCount, byte[] tgt, int tgtCount, int fromIndex) { assert fromIndex >= 0; assert tgtCount > 0; assert tgtCount <= tgt.length; assert srcCount >= tgtCount; // 目標字串的第一個字元 char first = (char)(tgt[0] & 255); // 最多找max次 int max = srcCount - tgtCount; // 從fromIndex處開始找 for(int i = fromIndex; i <= max; ++i) { // 如果該字元不等於first,接著i++,直到找到與first字元相等 if (getChar(src, i) != first) { do { ++i; } while(i <= max && getChar(src, i) != first); } if (i <= max) { int j = i + 1; int end = j + tgtCount - 1; // 一個個字元逐個比較 for(int k = 1; j < end && getChar(src, j) == (tgt[k] & 255); ++k) { ++j; } // 如果j==end 說明全部遍歷完都符合條件,返回首字元位置i if (j == end) { return i; } } } return -1; }
可以看出 Java String 的 contains 方法 原理還是用的逐個字元比較,沒有用別的效果稍微高但很複雜的方法;
以上就是Java String原始碼contains題解重複疊加字串匹配的詳細內容,更多關於Java String原始碼contains的資料請關注it145.com其它相關文章!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45