search
HomeJavajavaTutorialHow to remove all consecutive duplicates in a string in Java?

Algorithm:

One of the more common scenarios for the stack is the operation of strings, such as deduplication, backspacing, paths represented by strings, etc. The operations are often relatively Simple.

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

Question 1: Delete all adjacent duplicates in a string

Code implementation:

func removeDuplicates(S string) string {    ss := []byte(S)    var stacks []byte    for i := 0; i
 <p><strong>Topic 2: Compare strings containing backspaces</strong><br></p><p>Code implementation: <br></p><p></p><pre class="brush:php;toolbar:false">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> 0 { // 注意 ”#abc“这种#在最前面的情况                stacks = stacks[:len(stacks)-1]            }        }    }    return string(stacks)}</len>

Topic 3: Simplify the path

Code implementation:

<code>import "strings"</code><code>func simplifyPath(path string) string {</code><code>    tmps := strings.Split(path,"/")</code><code>    var paths []string</code><code>    for _,s:=range tmps {</code><code>        if len(s) != 0{</code><code>            paths = append(paths,s) </code><code>        }</code><code>    }</code><code>    // fmt.Println("name",paths)</code><code>    var stacks []string</code><code>    for i:=0;i<len><code><br></code><code>        if paths[i]==".." {</code><code>            if len(stacks) > 0{</code><code>                stacks=stacks[:len(stacks)-1]</code><code>            }</code><code>            continue</code><code>        }</code><code>        if paths[i]!="."{</code><code>            stacks=append(stacks,paths[i])</code><code>        }</code><code>    }</code><code>    // fmt.Println("name",stacks,len(stacks))</code><code>    resStr :=""</code><code>    for idx,s:=range stacks {</code><code>        resStr += s</code><code>        if idx != len(stacks)-1{</code><code>            resStr += "/"</code><code>        }  </code><code>    }</code><code><br></code><code>    return "/"+resStr</code><code>}</code></len></code>

The above is the detailed content of How to remove all consecutive duplicates in a string in Java?. For more information, please follow other related articles on the PHP Chinese website!

Statement
This article is reproduced at:亿速云. If there is any infringement, please contact admin@php.cn delete
Why do Word and PPT files become garbled TXT files when downloading files in Java?Why do Word and PPT files become garbled TXT files when downloading files in Java?Apr 19, 2025 pm 09:30 PM

Buffer issues in Java file download When using Java for file download, we may encounter some file type problems, such as downloading Word or PPT...

How to extract URLs ending in .com or .cn in Java regular expressions?How to extract URLs ending in .com or .cn in Java regular expressions?Apr 19, 2025 pm 09:27 PM

Tips for extracting specific texts by Java regular expressions In Java programming, we often need to extract content that conforms to a specific pattern from a piece of text. Regular...

What are the commonly used data structures in Java and what are their implementation principles?What are the commonly used data structures in Java and what are their implementation principles?Apr 19, 2025 pm 09:24 PM

Overview of commonly used data structures in Java In Java programming, the selection of data structures is crucial to improving the efficiency and performance of the program. So, what are there in Java...

How to distinguish between business logic and storage logic in back-end development?How to distinguish between business logic and storage logic in back-end development?Apr 19, 2025 pm 09:18 PM

How to distinguish between business logic and storage logic in the three-layer architecture of back-end development? In back-end development, common three-tier architectures include controller, service and...

When the front-end passes data to the back-end, the back-end displays that the obtained data is NULL. How to solve it?When the front-end passes data to the back-end, the back-end displays that the obtained data is NULL. How to solve it?Apr 19, 2025 pm 09:15 PM

Problem description: During the development process using Ruoyi separate version, when the front-end passes data to the back-end, the back-end displays that the obtained data is NULL. The following are...

How to use CompletableFuture to ensure the order of batch interface requests and efficiently process the results?How to use CompletableFuture to ensure the order of batch interface requests and efficiently process the results?Apr 19, 2025 pm 09:09 PM

Efficient processing of batch interface requests: Using CompletableFuture to ensure order When processing large amounts of data, concurrent calls to third-party interfaces can significantly improve efficiency...

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

SublimeText3 Linux new version

SublimeText3 Linux new version

SublimeText3 Linux latest version

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

MantisBT

MantisBT

Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

VSCode Windows 64-bit Download

VSCode Windows 64-bit Download

A free and powerful IDE editor launched by Microsoft

EditPlus Chinese cracked version

EditPlus Chinese cracked version

Small size, syntax highlighting, does not support code prompt function