ホームページ > Java > &#&チュートリアル > Javaで文字列内の連続する重複をすべて削除するにはどうすればよいですか?

Javaで文字列内の連続する重複をすべて削除するにはどうすればよいですか?

WBOY
リリース: 2023-04-24 19:04:13
転載
1383 人が閲覧しました

アルゴリズム:

スタックのより一般的なシナリオの 1 つは、重複排除、バックスペース、文字列で表されるパスなどの文字列の操作です。多くの場合、比較的単純です。

うわー

質問 1: 文字列内の隣接する重複をすべて削除します

コードの実装:

1.先把最为条件判断的字符串入栈2.根据新到来的元素判断要不要出栈3.最为比较的元素往往存在栈内,比较的时候,  有时候比较栈顶元素,有时候整个栈都要比较
ログイン後にコピー

トピック 2: バックスペースを含む文字列の比較

コード実装:

func removeDuplicates(S string) string {    ss := []byte(S)    var stacks []byte    for i := 0; i< len(ss);i++ {        if len(stacks) != 0 {            j:= len(stacks)-1            if ss[i] == stacks[j]{ // 与栈顶元素相同的话,删除栈内数据并且也不入栈                stacks = stacks[:j]                continue            }           }         stacks = append(stacks,ss[i])// 其他情况都入栈    }    return string(stacks)}/*栈的使用,先入栈,后面的元素与栈顶元素相同,出栈并且新元素不入栈。其他场景都入栈。*/
ログイン後にコピー

トピック 3: パスの簡素化

コード実装:

func backspaceCompare(S string, T string) bool {    s := getStack(S)    t := getStack(T)    return s == t}func getStack(S string) string {    ss := []byte(S)    var stacks []byte    for i:=0;i<len(ss);i++{        if ss[i] != &#39;#&#39; {            stacks = append(stacks,ss[i])        } else {            if len(stacks) > 0 { // 注意 ”#abc“这种#在最前面的情况                stacks = stacks[:len(stacks)-1]            }        }    }    return string(stacks)}
ログイン後にコピー

以上がJavaで文字列内の連続する重複をすべて削除するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:yisu.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート