下面是用 JavaScript 编写的程序员,以O(N^2)
时间复杂度和额外O(1)
空间查找给定字符串的所有可能子字符串;
程序
function genSubstrings ( inputString ){ debugger ; let resultArray = []; // outer loop to run n times [n = size of string] for ( let i = 0 ; i < inputString . length ; i ++ ){ // pushing first char of string as substring // as we know that each char will be substring itself too. resultArray . push ( inputString [ i ]); // inner loop to run n - 1 times; for ( let j = i + 1 ; j < inputString . length ; j ++ ){ // get last substring and append the new next char resultArray . push ( resultArray [ resultArray . length - 1 ] + inputString [ j ] ); } } return resultArray ; }
输出
genSubstrings ( " abcd " ); ( 10 ) [ ' a ' , ' ab ' , ' abc ' , ' abcd ' , ' b ' , ' bc ' , ' bcd ' , ' c ' , ' cd ' , ' d ' ]
我在互联网上搜索了一个更好的解决方案,它可以在小于 O(N^2) 的时间复杂度内运行,但没有找到。
如果有人有更好的解决方案,请在评论中写下,这将非常有帮助。
缩略图取自geekforgeek
原文: https://dev.to/rajeshroyal/find-all-substring-of-a-given-string-in-on2-time-2ip7