{"trustable":true,"prependHtml":"\u003cscript\u003e window.katexOptions \u003d { disable: true }; \u003c/script\u003e\n\u003cscript type\u003d\"text/x-mathjax-config\"\u003e\n MathJax.Hub.Config({\n tex2jax: {\n inlineMath: [[\u0027$$$\u0027,\u0027$$$\u0027], [\u0027$\u0027,\u0027$\u0027]],\n displayMath: [[\u0027$$$$$$\u0027,\u0027$$$$$$\u0027], [\u0027$$\u0027,\u0027$$\u0027]]\n }\n });\n\u003c/script\u003e\n\u003cscript async src\u003d\"https://mathjax.codeforces.org/MathJax.js?config\u003dTeX-AMS-MML_HTMLorMML\" type\u003d\"text/javascript\"\u003e\u003c/script\u003e","sections":[{"title":"","value":{"format":"HTML","content":"\u003cdiv class\u003d\"panel_content\"\u003eЕсть последовательность $a$ длиной $n$. Мы используем $a_i$, чтобы обозначить $i$-й элемент в этой последовательности. Вам нужно выполнить следующие три типа операций с этой последовательностью.\u003cbr\u003e\u003cbr\u003e $0\\ x\\ y\\ t$: Для каждого $x \\le i \\le y$ мы используем $min(a_i, t)$, чтобы заменить значение исходного $a_i$.\u003cbr\u003e $1\\ x\\ y$: Вывести максимальное значение $a_i$, которое $x \\le i \\le y$.\u003cbr\u003e $2\\ x\\ y$: Вывести сумму $a_i$, которые $x \\le i \\le y$.\u003cbr\u003e\u003c/div\u003e"}},{"title":"Ввод","value":{"format":"HTML","content":"Первая строка ввода - это одно целое число $T$, указывающее количество тестов. \u003cbr\u003e\u003cbr\u003eПервая строка содержит два целых числа $n$ и $m$, обозначающих длину последовательности и количество операций.\u003cbr\u003e\u003cbr\u003eВторая строка содержит $n$ отдельных целых чисел $a_1, \\ldots, a_n$ ($\\forall 1 \\le i \\le n, 0 \\le a_i \u0026lt; 2^{31}$).\u003cbr\u003e\u003cbr\u003eКаждая из следующих $m$ строк представляет одну операцию ($1 \\le x \\le y \\le n, 0\\le t \u0026lt; 2^{31}$).\u003cbr\u003e\u003cbr\u003eГарантируется, что $T\u003d100$, $\\sum n \\le 1000000, \\ \\sum m \\le 1000000$."}},{"title":"Вывод","value":{"format":"HTML","content":"Для каждой операции типа $1$ или $2$, выведите одну строку, содержащую ответ на соответствующий запрос.\u003cbr\u003e"}},{"title":"Пример","value":{"format":"HTML","content":"\u003ctable class\u003d\u0027vjudge_sample\u0027\u003e\n\u003cthead\u003e\n \u003ctr\u003e\n \u003cth\u003eInput\u003c/th\u003e\n \u003cth\u003eOutput\u003c/th\u003e\n \u003c/tr\u003e\n\u003c/thead\u003e\n\u003ctbody\u003e\n \u003ctr\u003e\n \u003ctd\u003e\u003cpre\u003e1\r\n5 5\r\n1 2 3 4 5\r\n1 1 5\r\n2 1 5\r\n0 3 5 3\r\n1 1 5\r\n2 1 5\r\n\u003c/pre\u003e\u003c/td\u003e\n \u003ctd\u003e\u003cpre\u003e5\r\n15\r\n3\r\n12\u003c/pre\u003e\u003c/td\u003e\n \u003c/tr\u003e\n\u003c/tbody\u003e\n\u003c/table\u003e"}},{"title":"Подсказка","value":{"format":"HTML","content":"Пожалуйста, используйте эффективный метод ввода-вывода"}}]}