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!

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...

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...

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...

Deploying SAAS applications in production environments: Docker...

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...

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...

In-depth discussion of Java...

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...


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

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

Hot Article

Hot Tools

SublimeText3 Linux new version
SublimeText3 Linux latest version

SublimeText3 Mac version
God-level code editing software (SublimeText3)

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
A free and powerful IDE editor launched by Microsoft

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function