trang chủ / bài tập / childseq

Dãy số của cậu bé

Đề bài

Mô tả

Cho một dãy số nguyên a1,a2,,an. Bạn cần thực hiện m thao tác, mỗi thao tác thuộc một trong ba loại sau:

  • Loại 11 l r: In ra tổng al+al+1++ar.
  • Loại 22 l r x: Với mọi i thỏa lir, gán ai=aimodx (phần dư khi chia ai cho x).
  • Loại 33 k x: Gán ak=x.

Hãy thực hiện toàn bộ dãy thao tác theo đúng thứ tự và in ra kết quả của mỗi thao tác loại 1.

Dữ liệu vào

  • Dòng đầu tiên chứa hai số nguyên nm.
  • Dòng thứ hai chứa n số nguyên a1,a2,,an.
  • m dòng tiếp theo, mỗi dòng mô tả một thao tác:
    • Nếu bắt đầu bằng số 1: tiếp theo là hai số nguyên l,r (1lrn).
    • Nếu bắt đầu bằng số 2: tiếp theo là ba số nguyên l,r,x (1lrn; 1x109).
    • Nếu bắt đầu bằng số 3: tiếp theo là hai số nguyên k,x (1kn; 1x109).

Dữ liệu ra

Với mỗi thao tác loại 1, in ra một dòng chứa tổng tương ứng. Lưu ý kết quả có thể vượt quá phạm vi số nguyên 32-bit.

Ràng buộc

  • 1n,m105
  • 1ai109

Ví dụ

Input Output Giải thích
5 5
1 2 3 4 5
2 3 5 4
3 3 5
1 2 5
2 1 3 3
1 1 3
8
5
Ban đầu a=[1,2,3,4,5].
Sau thao tác 2 (mod 4 trên đoạn [3,5]): a=[1,2,3,0,1].
Sau thao tác 3 (gán a3=5): a=[1,2,5,0,1].
Thao tác 1 trên [2,5]: 2+5+0+1=8.
Sau thao tác 2 (mod 3 trên đoạn [1,3]): a=[1,2,2,0,1].
Thao tác 1 trên [1,3]: 1+2+2=5.
1 1
1000000000
1 1 1
1000000000 Dãy chỉ có một phần tử; thao tác 1 in ra chính giá trị đó.

Bình luận

Không có bình luận tại thời điểm này.

gnatmake 12.2.0 a68g 3.1.2 nasm 2.16.1 as_x64 2.46 awk 1.3.4 gcc 16.1.0 csc 6.12.0.200 g++ 16.1.0 g++-themis 16.1.0 g++17 16.1.0 g++20 16.1.0 g++23 16.1.0 clang++ 22.1.6 dmd 2.112.0 dart 3.12.1 gforth 0.7.3 gfortran 12.2.0 GO groovyc 5.0.6 javac 25.0.3 node 26.2.0 kotlinc 2.3.21 sbcl 2.2.9 lua 5.4.8 nim 2.2.10 fpc 3.2.2 fpc-themis 3.2.2 perl 5.36.0 php 8.5.6 pike 8.0 pypy3 7.3.23 python3 3.14.5 racket 8.7 ruby 4.0.5 rustc 1.96.0 csc 5.3.0 ctoj-scratch 0.0.1 sed 4.9 tclsh 8.6 bun 1.3.14 deno 2.8.1 v 0.5.1 zig 0.16.0