package main import . "fmt" import . "os" import bf "bufio" func main() { rd:=bf.NewReader(Stdin) var n,h int Fscan(rd,&n,&h) a := make([]int, n) for i := range a { Fscan(rd,&a[i]) } b := make([]int, n) for i := range b { Fscan(rd,&b[i]) } var ans int s,t,tt := a[0],b[0],b[0] l,r := 0, 0 for { // println(Sprintf("l=%d,r=%d,s=%d,t=%d,tt=%d",l,r,s,t,tt)) for tt > h { tt -= t t -= b[l] s -= a[l] l++ } ans = max(ans, s) // println(Sprintf("ans=%d",ans)) r++ if r >= n { break } s += a[r] t += b[r] tt += (r-l+1)*b[r] } Println(ans) }