mirror of
https://github.com/halfrost/LeetCode-Go.git
synced 2025-07-05 16:36:41 +08:00
Add Biweekly 40
This commit is contained in:
@ -0,0 +1,18 @@
|
||||
package leetcode
|
||||
|
||||
import (
|
||||
"strings"
|
||||
)
|
||||
|
||||
func maxRepeating(sequence string, word string) int {
|
||||
for i := len(sequence) / len(word); i >= 0; i-- {
|
||||
tmp := ""
|
||||
for j := 0; j < i; j++ {
|
||||
tmp += word
|
||||
}
|
||||
if strings.Contains(sequence, tmp) {
|
||||
return i
|
||||
}
|
||||
}
|
||||
return 0
|
||||
}
|
@ -0,0 +1,53 @@
|
||||
package leetcode
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"testing"
|
||||
)
|
||||
|
||||
type question1665 struct {
|
||||
para1665
|
||||
ans1665
|
||||
}
|
||||
|
||||
// para 是参数
|
||||
// one 代表第一个参数
|
||||
type para1665 struct {
|
||||
sequence string
|
||||
word string
|
||||
}
|
||||
|
||||
// ans 是答案
|
||||
// one 代表第一个答案
|
||||
type ans1665 struct {
|
||||
one int
|
||||
}
|
||||
|
||||
func Test_Problem1665(t *testing.T) {
|
||||
|
||||
qs := []question1665{
|
||||
|
||||
{
|
||||
para1665{"ababc", "ab"},
|
||||
ans1665{2},
|
||||
},
|
||||
|
||||
{
|
||||
para1665{"ababc", "ba"},
|
||||
ans1665{1},
|
||||
},
|
||||
|
||||
{
|
||||
para1665{"ababc", "ac"},
|
||||
ans1665{0},
|
||||
},
|
||||
}
|
||||
|
||||
fmt.Printf("------------------------Leetcode Problem 1665------------------------\n")
|
||||
|
||||
for _, q := range qs {
|
||||
_, p := q.ans1665, q.para1665
|
||||
fmt.Printf("【input】:%v 【output】:%v \n", p, maxRepeating(p.sequence, p.word))
|
||||
}
|
||||
fmt.Printf("\n\n\n")
|
||||
}
|
@ -0,0 +1,46 @@
|
||||
package leetcode
|
||||
|
||||
import (
|
||||
"github.com/halfrost/LeetCode-Go/structures"
|
||||
)
|
||||
|
||||
// ListNode define
|
||||
type ListNode = structures.ListNode
|
||||
|
||||
/**
|
||||
* Definition for singly-linked list.
|
||||
* type ListNode struct {
|
||||
* Val int
|
||||
* Next *ListNode
|
||||
* }
|
||||
*/
|
||||
|
||||
func mergeInBetween(list1 *ListNode, a int, b int, list2 *ListNode) *ListNode {
|
||||
pre, cur, list2Cur := list1, list1.Next, list2
|
||||
for cur.Next != nil {
|
||||
if cur.Val == a {
|
||||
pre.Next = list2
|
||||
pre = cur
|
||||
break
|
||||
}
|
||||
pre = cur
|
||||
cur = cur.Next
|
||||
}
|
||||
cur = cur.Next
|
||||
for list2Cur.Next != nil {
|
||||
list2Cur = list2Cur.Next
|
||||
}
|
||||
if a == b {
|
||||
list2Cur.Next = cur
|
||||
return list1
|
||||
}
|
||||
for cur.Next != nil {
|
||||
if cur.Val == b {
|
||||
list2Cur.Next = cur.Next
|
||||
break
|
||||
}
|
||||
pre = cur
|
||||
cur = cur.Next
|
||||
}
|
||||
return list1
|
||||
}
|
@ -0,0 +1,62 @@
|
||||
package leetcode
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"testing"
|
||||
|
||||
"github.com/halfrost/LeetCode-Go/structures"
|
||||
)
|
||||
|
||||
type question2 struct {
|
||||
para2
|
||||
ans2
|
||||
}
|
||||
|
||||
// para 是参数
|
||||
// one 代表第一个参数
|
||||
type para2 struct {
|
||||
one []int
|
||||
a int
|
||||
b int
|
||||
another []int
|
||||
}
|
||||
|
||||
// ans 是答案
|
||||
// one 代表第一个答案
|
||||
type ans2 struct {
|
||||
one []int
|
||||
}
|
||||
|
||||
func Test_Problem2(t *testing.T) {
|
||||
|
||||
qs := []question2{
|
||||
|
||||
{
|
||||
para2{[]int{0, 1, 2, 3, 4, 5}, 3, 4, []int{1000000, 1000001, 1000002}},
|
||||
ans2{[]int{0, 1, 2, 1000000, 1000001, 1000002, 5}},
|
||||
},
|
||||
|
||||
{
|
||||
para2{[]int{0, 1, 2, 3, 4, 5, 6}, 2, 5, []int{1000000, 1000001, 1000002, 1000003, 1000004}},
|
||||
ans2{[]int{0, 1, 1000000, 1000001, 1000002, 1000003, 1000004, 6}},
|
||||
},
|
||||
|
||||
{
|
||||
para2{[]int{0, 1, 2, 3, 4, 5, 6, 7, 8, 9}, 3, 5, []int{1000000, 1000001, 1000002, 1000003, 1000004, 1000005, 1000006}},
|
||||
ans2{[]int{0, 1, 2, 1000000, 1000001, 1000002, 1000003, 1000004, 1000005, 1000006, 6, 7, 8, 9}},
|
||||
},
|
||||
|
||||
{
|
||||
para2{[]int{0, 1, 2}, 1, 1, []int{1000000, 1000001, 1000002, 1000003}},
|
||||
ans2{[]int{0, 1000000, 1000001, 1000002, 1000003, 2}},
|
||||
},
|
||||
}
|
||||
|
||||
fmt.Printf("------------------------Leetcode Problem 2------------------------\n")
|
||||
|
||||
for _, q := range qs {
|
||||
_, p := q.ans2, q.para2
|
||||
fmt.Printf("【input】:%v 【output】:%v\n", p, structures.List2Ints(mergeInBetween(structures.Ints2List(p.one), p.a, p.b, structures.Ints2List(p.another))))
|
||||
}
|
||||
fmt.Printf("\n\n\n")
|
||||
}
|
Reference in New Issue
Block a user