← Home
```go
package main

import (
	"bufio"
	"os"
	"strconv"
)

const MOD int64 = 1000000007

var fact [100005]int64
var invFact [100005]int64
var pow25 [100005]int64
var pow26 [100005]int64

func init() {
	fact[0] = 1
	invFact[0] = 1
	pow25[0] = 1
	pow26[0] = 1
	for i := 1; i <= 100000; i++ {
		fact[i] = (fact[i-1] * int64(i)) % MOD
		pow25[i] = (pow25[i-1] * 25) % MOD
		pow26[i] = (pow26[i-1] * 26) % MOD
	}
	invFact[100000] = power(fact[100000], MOD-2)
	for i := 99999; i >= 1; i-- {
		invFact[i] = (invFact[i+1] * int64(i+1)) % MOD
	}
}

func power(base, exp int64) int64 {
	res := int64(1)
	base %= MOD
	for exp > 0 {
		if exp%2 == 1 {
			res = (res * base) % MOD
		}
		base = (base * base) % MOD
		exp /= 2
	}
	return res
}

func nCr(n, r int) int64 {
	if r < 0 || r > n {
		return 0
	}
	return fact[n] * invFact[r] % MOD * invFact[n-r] % MOD
}

type Query struct {
	id int
	n  int
}

func main() {
	scanner := bufio.NewScanner(os.Stdin)
	scanner.Buffer(make([]byte, 1024*1024), 1024*1024*10)
	scanner.Split(bufio.ScanWords)

	if !scanner.Scan() {
		return
	}
	m, _ := strconv.Atoi(scanner.Text())

	scanner.Scan()
	s := scanner.Text()
	k := len(s)

	queriesByK := make(map[int][]Query)
	var queryCount int

	for i := 0; i < m; i++ {
		scanner.Scan()
		t, _ := strconv.Atoi(scanner.Text())
		if t == 1 {
			scanner.Scan()
			s = scanner.Text()
			k = len(s)
		} else {
			scanner.Scan()
			n, _ := strconv.Atoi(scanner.Text())
			queriesByK[k] = append(queriesByK[k], Query{id: queryCount, n: n})
			queryCount++
		}
	}

	ans := make([]int64, queryCount)
	var k_ans [100005]int64

	for kVal, queries := range queriesByK {
		maxN := 0
		for _, q := range queries {
			if q.n > maxN {
				maxN = q.n
			}
		}

		if maxN >= kVal {
			S := (pow26[kVal] - 1 + MOD) % MOD
			k_ans[kVal] = 1
			for n := kVal; n < maxN; n++ {
				term := (nCr(n, kVal-1) * pow25[n-kVal+1]) % MOD
				S = (26*S - term) % MOD
				if S < 0 {
					S += MOD
				}
				k_ans[n+1] = (pow26[n+1] - S + MOD) % MOD
			}
		}

		for _, q := range queries {
			if q.n >= kVal {
				ans[q.id] = k_ans[q.n]
			} else {
				ans[q.id] = 0
			}
		}
	}

	out := bufio.NewWriter(os.Stdout)
	for i := 0; i < queryCount; i++ {
		out.WriteString(strconv.FormatInt(ans[i], 10) + "\n")
	}
	out.Flush()
}
```