You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
|
package main
|
|
|
|
|
|
|
|
type NodeL struct {
|
|
|
|
Data interface{}
|
|
|
|
Next *NodeL
|
|
|
|
}
|
|
|
|
|
|
|
|
type List struct {
|
|
|
|
Head *NodeL
|
|
|
|
Tail *NodeL
|
|
|
|
}
|
|
|
|
|
Refactor & Beautify & destruction commit
return early, remove else branches, reorder conditions and top-level functions, remove empty lines, remove unnecessary append(), fix typos, stop using testing package, remove dead code, fix mistakes in subjects, tests and solutions, remove disclaimers, reformat comments, simplify solutions, tests, add more instructions to subjects, remove obsolete files, etc.
Some of the reasons behind those modifications will be added to good-practices.en.md
Some of the exercises are now broken, they will have to be fixed, most of them have a "TODO:" comment.
5 years ago
|
|
|
// removes all elements that are equal to the data_ref
|
|
|
|
func ListRemoveIf(l *List, data_ref interface{}) {
|
|
|
|
temp := l.Head
|
|
|
|
prev := l.Head
|
|
|
|
|
|
|
|
for temp != nil && temp.Data == data_ref {
|
|
|
|
l.Head = temp.Next
|
|
|
|
temp = l.Head
|
|
|
|
}
|
|
|
|
for temp != nil {
|
|
|
|
if temp.Data != data_ref {
|
|
|
|
prev = temp
|
|
|
|
}
|
|
|
|
|
|
|
|
prev.Next = temp.Next
|
|
|
|
temp = prev.Next
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
}
|