国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

word文檔解密方法說明

PLC工控專欄 ? 來源:PLC工控專欄 ? 作者:PLC工控專欄 ? 2022-03-14 09:05 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

word文檔解密方法,【徽信;sjk6070】當我們求取最長回文子串時,常見的方法就是中心擴散法,即從字符中心出發,向兩邊對比,檢查是否相等,若等于,則繼續檢查,并使當前字符中心對應的最長回文子串長度加一,否則,結束該字符中心的回文檢查,比較與當前整個字符串的最長回文子串,考慮是否更新整個字符串的最長回文子串長度,繼續進行下一個字符的判斷。

這種方法的時間復雜度仍為 O(n2)O(n^2)O(n2) ,較普通的暴力破解的方法有著不錯的優化,但也不是最佳的思路,相關的代碼如下:

public class Solution {
private int max = 0;
private String res = “”;
public String longestPalindrome(String s) {
if (s.length() == 1) { return s; }
for (int i = 0; i < s.length()-1; i++) {
checkPalindromeExpand(s,i,i);
checkPalindromeExpand(s,i,i+1);
}
return res;
}
public void checkPalindromeExpand(String s, int low, int high) {
while (low >= 0 && high < s.length()) {
if (s.charAt(low) == s.charAt(high)) {
if (high - low + 1 > max) {
max = high - low + 1;
res = s.substring(low,high+1);
}
low–; high++;
} else {
return;
}
}
}
}
復制代碼
當然,上面這種算法也有優化的空間,基本的思路如下:

統計字符出現頻率,用數組表示出現頻率,當某個字符出現頻率為 1 時,認為該字符可能為某段回文子串的中心點,否則,就不屬于任何一個回文子串
找出頻度為1的字符a,看以a為單核中心向外擴散,求最長回文;如果沒有回文,就將它從串中斷開,進行分治;如果回文長度超過記錄,就保存它
然后從左到右查回文,只有長度超過記錄,才保存
第一次串分割完畢后,進行分治,重新統計頻度,回到1步驟

實現代碼可以借鑒:小馬哥最長回文子串長度求取
Manachar算法
求取最長回文子串的長度的最佳方法為 Manachar算法 ,俗稱馬拉車算法。在了解這個算法之前,我們必須先理解回文子串的一些性質:

假設對于一個回文串,以及其中心位置,由回文串的性質可知,從其中心向兩側逐步擴散到邊界為止,每一步所對應范圍的字串都是回文串

如果我們已知一個回文串的中心點 mid 與其邊界范圍。那么,在大多數情況下,位于邊界內且關于此中心點對稱的兩點a、b,如果有回文串以 a 為中心,那么以 b 為中心的回文串與以 a 為中心的回文串完全相同。并且,它們之間存在這樣的關系:b=2×mid?ab = 2 \times mid - ab=2×mid?a

回文串末尾位置到回文串中心位置的字符長度為該回文串的半徑,若末尾位置的下標為 a ,中心位置的下標為 id ,回文串長度半徑為 len ,即半徑為 len 則它們存在如下關系:
a=id+len÷2a = id + len\div2a=id+len÷2
頭尾添加一個非 * 的特殊符號保證不越界,避免多次判斷是否越界。

為方便處理,將字符串長度可能為奇數,可能為偶數的兩種情況進行合并,即在每個字符的左右都加上一個特殊字符,比如 “?*?”。防止越界情況的出現,在開頭添加一個 “@”可看如下實踐:

從以上實踐可得出,由于插入的 # 號的個數必定等于字符個數加一再加上 兩個@ 字符,所以總長度是偶數+奇數=奇數,通過這種方法,可以將字符串的長度都化為奇數,這樣就不需要對長度奇偶性進行分情況討論。
對字符串完成預處理之后,定義一個數組 len 存入字符串的每個字符作為回文串中心擴散的回文子串長度且為去掉特殊字符的原字符串的總長。

最長回文子串長度:len[i]?1最長回文子串長度:len[i]-1最長回文子串長度:len[i]?1
證明方法如下:

轉換后,所有回文子串的長度為奇數,故以中心位置下標為 i 的最長回文串長度為 2×len[i]?12 \times len[i] - 12×len[i]?1
在回文串中,特殊字符數為 len[i] ,而除去特殊字符數剩下的就為原字符數,即 (2×len[i]?1)?len[i]=len[i]?1(2\times len[i]-1)- len[i] = len[i] -1(2×len[i]?1)?len[i]=len[i]?1

問題就轉換為了求取 len[i] 中所有的數。
已知 P 的最長回文子串長度 len[p],則回文串左邊界為 p - len[p],右邊界為 p + len[p]
假設在已知中心 p 的左邊有一點 j ,其對稱點為 i,

若 i > len[p] + p ,暴力比較 ,通常出現在求取最開始時。
若 i < len[p] + p ,且 len[j] < len[p] + p - i (右邊界到 i 的距離),則他被完全包裹入以 p 為中心的子串中,必有 len[i] = len[j]
若 i = len[p] + p ,且 len[j] >= len[p] + p - i , len[i] = len[j],此時,可能存在超出原有 p 的回文區域,仍需從邊界 i + 1 + len[i] 出發一一比較

做完當前中心 i 的長度求取之后,判斷是否 i 的回文區域右邊界大于原有回文右邊界值,若大于,更新中心點為 i ,右邊界為 i 的回文右邊界。
解決 len 數組的求取問題就基本完成對于 Manachar 算法的理解。相關代碼如下:
import java.util.Scanner;

public class Manacher {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
String str = in.next();
String res = longestPalindrome(str);
System.out.println(res + ": " + res.length());
}
//插入字符
public static String preProcess(String s) {
int n = s.length();
if (n == 0) {
return “^KaTeX parse error: Expected 'EOF', got '}' at position 12: "; }? String…”;
return ret;
}
// 馬拉車算法
public static String longestPalindrome(String str) {
String S = preProcess(str);
int n = S.length();// 保留回文串的長度
int[] len = new int[n];
int center = 0, right = 0;// 保留邊界最右的回文核心以及右邊界
// 從第 1 個字符開始
for (int i = 1; i < n - 1; i++) {
// 找出i對于后面核心的對稱
int mirror = 2 * center - i;
if (right > i) {
// i 在右邊界的范疇內,看看i的對稱點的回文串長度,以及i到右邊界的長度,取兩個較小的那個
// 不能溢出之前的邊界,否則就得核心拓展
len[i] = Math.min(right - i, len[mirror]);
} else {
// 超過范疇了,核心拓展
len[i] = 0;
}

// 核心拓展
while (S.charAt(i + 1 + len[i]) == S.charAt(i - 1 - len[i])) {
len[i]++;
}

// 看看新的索引是不是比之前保留的最右邊界的回文串還要靠右
if (i + len[i] > right) {
// 更新核心
center = i;
// 更新右邊界
right = i + len[i];
}

}

// 通過回文長度數組找出最長的回文串
int maxLen = 0;
int centerIndex = 0;
for (int i = 1; i < n - 1; i++) {
if (len[i] > maxLen) {
maxLen = len[i];
centerIndex = i;
}
}
int start = (centerIndex - maxLen) / 2;
return str.substring(start, start + maxLen);
}


審核編輯:湯梓紅

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • word
    +關注

    關注

    1

    文章

    79

    瀏覽量

    22765
  • 字符
    +關注

    關注

    0

    文章

    237

    瀏覽量

    26195
  • 文檔
    +關注

    關注

    0

    文章

    48

    瀏覽量

    12346
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    單片機解密是什么?

    單片機解密是什么? 單片機解密又叫單片機**,芯片解密,IC解密,但是這嚴格說來這幾種稱呼都不科學,但已經成 了習慣叫法,我們把CPLD解密
    發表于 12-30 08:19

    pdf轉換成word文檔格式亂了

    ,不是文檔結構,當軟件試圖把排版映射回可編輯的 word 元素時,必須猜測各部分關系,這些猜測可能錯尤其是有多欄、混合字體或掃描圖片的復雜頁面.下面講為什么格式會出問題,先檢查什么,以及用簡單方法如何得到更整潔的
    的頭像 發表于 11-22 10:04 ?1080次閱讀

    STSW-STM32080文檔說明

    電子發燒友網站提供《STSW-STM32080文檔說明.pdf》資料免費下載
    發表于 11-20 17:18 ?1次下載

    AES加解密算法邏輯實現及其在蜂鳥E203SoC上的應用介紹

    乘法,但是如果直接使用verilog實現矩陣乘法會導致面積開銷大,建議方法是先對矩陣乘法進行共享項合并,從而顯著漸少面積開銷,同時加密中使用的列混淆運算和解密中使用的列混淆運算可以再進行共享項合并,從而
    發表于 10-29 07:29

    ulog_tag_lvl_filter_set()函數無法實現按照文檔說明那樣實現按模塊過濾,怎么解決?

    ulog_tag_lvl_filter_set()函數無法實現按照文檔說明那樣實現按模塊過濾,比如過濾掉所有drv.xxx的日志
    發表于 10-10 07:30

    CST92F25的文檔

    CST92F25的開發文檔說明還是比較全的,就是表達不夠清晰,需要自己揣摩。
    發表于 07-20 14:01

    使用Word/Excel管理需求的10個痛點及解決方案Perforce ALM

    還在用Word/Excel做需求管理?10個“翻車信號”,都是小伙伴們踩過的坑~來看看你踩過哪些?是不是也該升級到更專業的ALM工具了~
    的頭像 發表于 07-10 15:59 ?664次閱讀
    使用<b class='flag-5'>Word</b>/Excel管理需求的10個痛點及解決方案Perforce ALM

    harmony-utils之AES,AES加解密

    harmony-utils之AES,AES加解密 harmony-utils 簡介與說明 [harmony-utils] 一款功能豐富且極易上手的HarmonyOS工具庫,借助眾多實用工具類,致力于
    的頭像 發表于 06-30 17:30 ?650次閱讀

    harmony-utils之DES,DES加解密

    harmony-utils之DES,DES加解密 harmony-utils 簡介與說明 [harmony-utils]一款功能豐富且極易上手的HarmonyOS工具庫,借助眾多實用工具類,致力于
    的頭像 發表于 06-30 17:16 ?511次閱讀

    harmony-utils之RSA,RSA加解密

    harmony-utils之RSA,RSA加解密 harmony-utils 簡介與說明 [harmony-utils] 一款功能豐富且極易上手的HarmonyOS工具庫,借助眾多實用工具類,致力于
    的頭像 發表于 06-30 16:52 ?979次閱讀

    harmony-utils之SM2,SM2加解密

    harmony-utils之SM2,SM2加解密 harmony-utils 簡介與說明 [harmony-utils] 一款功能豐富且極易上手的HarmonyOS工具庫,借助眾多實用工具類,致力于
    的頭像 發表于 06-30 16:47 ?758次閱讀

    基于SM4的文件加密解密功能實現(ECB模式)

    : ?? 相關技術實現思路如下: 一、SM4加密解密 大部分的代碼官網都有,我這里先介紹一下我的開發中踩坑的記錄 如果看官方文檔里的代碼,你會發現,他對于加密解密的演示,是直接把加密后的結果,扔給
    發表于 06-29 13:21

    harmony-utils之SM4,SM4加解密

    harmony-utils之SM4,SM4加解密 harmony-utils 簡介與說明 harmony-utils 一款功能豐富且極易上手的HarmonyOS工具庫,借助眾多實用工具類,致力于助力
    的頭像 發表于 06-28 18:36 ?744次閱讀

    GLAD:利用全息圖實現加密和解密

    概述 全息圖能夠通過兩束相干光相干疊加獲得。用其中一束光照射生成的全息圖就可以得到另一束相干光,這樣全息圖就可以用作加密/解密的裝置了。 系統描述 在本例中一個復雜的隨機圖樣作為參考光源,用來恢復
    發表于 06-13 08:42

    stellar studio按照說明文檔進行編譯器環境配置,為什么會報錯?

    已經是按照說明文檔進行編譯器環境配置,但是還是會報錯,問題大概可能是文件系統操作錯誤,無法訪問打開文件,看樣子像系統問題,但是其他同學有和我系統版本號一樣的也可以編譯運行,具體錯誤點擊也無法跳轉到錯誤位置
    發表于 06-12 07:49