日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

上海大都会 H.A Simple Problem with Integers

發(fā)布時(shí)間:2023/11/30 编程问答 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 上海大都会 H.A Simple Problem with Integers 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

題目描述

You have N integers A1, A2, ... , AN. You are asked to write a program to receive and execute two kinds of instructions:

  • C a b means performing Ai = (Ai2 mod 2018) for all Ai such that a ≤ i ≤ b.
  • Q a b means query the sum of Aa, Aa+1, ..., Ab. Note that the sum is not taken modulo 2018.
  • 輸入描述:

    The first line of the input is T(1≤ T ≤ 20), which stands for the number of test cases you need to solve.
    The first line of each test case contains N (1 ≤ N ≤ 50000).The second line contains N numbers, the initial values of A1, A2, ..., An.? 0 ≤ Ai < 2018. The third line contains the number of operations Q (0 ≤ Q ≤ 50000). The following Q lines represents an operation having the format "C a b" or "Q a b", which has been described above. 1 ≤ a ≤ b ≤ N.

    輸出描述:

    For each test case, print a line "Case #t:" (without quotes, t means the index of the test case) at the beginning.
    You need to answer all Q commands in order. One answer in a line.

    分析

    剛開(kāi)始打表算錯(cuò)了周期。。。又坑隊(duì)友了
    每個(gè)元素平方最大周期為6,且6是其他所有周期的公倍數(shù)。我們可以在每個(gè)節(jié)點(diǎn)維護(hù)一個(gè)大小為6的數(shù)組,同時(shí)維護(hù)一個(gè)代表從數(shù)組中取哪個(gè)元素的指針。因?yàn)橛械臄?shù)在進(jìn)入循環(huán)節(jié)前需要經(jīng)過(guò)幾次修改,打表發(fā)現(xiàn)進(jìn)入循環(huán)節(jié)前的修改次數(shù)都不超過(guò)5,所以可以在前五次暴力更新節(jié)點(diǎn),之后才開(kāi)始利用線段樹(shù)的lazy標(biāo)記。

    代碼

    #include <iostream> #include <cstdio> #include <cstring> #include <vector> #include <stack> #include <algorithm> using namespace std; typedef long long ll; const int mod=2018; const int maxn=50050; int cnt[maxn*4],sum[maxn*4][7],lazy[maxn*4],p[maxn*4]; void build(int l,int r,int id) {cnt[id]=p[id]=lazy[id]=0;if(l==r) {scanf("%d", &sum[id][0]);}else {int mid=(l+r)>>1;build(l,mid,id<<1);build(mid+1,r,id<<1|1);sum[id][0]=sum[id<<1][0]+sum[id<<1|1][0];} } void pushUp(int id) {cnt[id]=min(cnt[id<<1],cnt[id<<1|1]);if(cnt[id]>=5) {p[id]=0;for (int i = 0; i < 6; ++i)sum[id][i]=sum[id<<1][(p[id<<1]+i)%6]+sum[id<<1|1][(p[id<<1|1]+i)%6];}else sum[id][0]=sum[id<<1][p[id<<1]]+sum[id<<1|1][p[id<<1|1]]; } void pushDown(int id) {p[id<<1]=(p[id<<1]+lazy[id])%6,lazy[id<<1]+=lazy[id];p[id<<1|1]=(p[id<<1|1]+lazy[id])%6,lazy[id<<1|1]+=lazy[id];lazy[id]=0; } void modify(int x,int y,int l,int r,int id) {if(l>r||l>y||r<x) return;if(l==r) {cnt[id]++;if(cnt[id]<5) {sum[id][0]=sum[id][0]*sum[id][0]%mod;}else if(cnt[id]==5) {p[id]=0;sum[id][0]=sum[id][0]*sum[id][0]%mod;for (int i = 1; i < 6; ++i){sum[id][i]=sum[id][i-1]*sum[id][i-1]%mod;}}else {p[id]=(p[id]+1)%6;}return;}if(lazy[id]) pushDown(id);if(x<=l&&y>=r) {int mid=(l+r)>>1;if(cnt[id]<5) {modify(x,y,l,mid,id<<1);modify(x,y,mid+1,r,id<<1|1);pushUp(id);}else {lazy[id]++;p[id]=(p[id]+1)%6;}return;}int mid=(l+r)>>1;if(x<=mid) modify(x,y,l,mid,id<<1);if(y>mid) modify(x,y,mid+1,r,id<<1|1);pushUp(id); } int query(int x,int y,int l,int r,int id) {if(l!=r && lazy[id]) pushDown(id);if(l>=x&&r<=y) {return sum[id][p[id]%6];}int mid=(l+r)>>1;int ans=0;if(x<=mid) ans+=query(x,y,l,mid,id<<1);if(y>mid) ans+=query(x,y,mid+1,r,id<<1|1);return ans; } int main(int argc, char const *argv[]) {int t,Case=0;scanf("%d", &t);while(t--){int n;scanf("%d", &n);build(1,n,1);int q;scanf("%d", &q);printf("Case #%d:\n", ++Case);while(q--){char str[3];int l,r;scanf("%s%d%d", str,&l,&r);if(str[0]=='Q') {printf("%d\n", query(l,r,1,n,1));}else {modify(l,r,1,n,1);}}}return 0; }

    轉(zhuǎn)載于:https://www.cnblogs.com/sciorz/p/9428114.html

    創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來(lái)咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)

    總結(jié)

    以上是生活随笔為你收集整理的上海大都会 H.A Simple Problem with Integers的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

    如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 亚洲国产mv| 国产乱人对白 | 天天干夜夜艹 | av在线激情 | 黄色免费一级片 | 国内精品久久久久久久影视简单 | 国产大屁股喷水视频在线观看 | 91夫妻论坛 | 一级黄色欧美 | 99久久国 | 91小仙女jk白丝袜呻吟 | 兄弟兄弟全集免费观看 | 日韩av三级在线观看 | 手机免费看av片 | 日韩视频精品在线 | 日本免费小视频 | 性高潮久久久久 | 白浆av | 欧美激情国产在线 | 欧美激情综合色综合啪啪五月 | 成人久色 | 无码aⅴ精品一区二区三区 精品久久在线 | 免费在线观看黄色av | 国产日日干 | av在线一区二区三区 | 午夜日韩欧美 | 中文字幕在线视频精品 | 国产3级| 四虎影院www| free性欧美hd精品4k | 黄色污网站在线观看 | 日本激情网 | 春色影视 | 高清三区 | 日本精品在线视频 | 韩日一级片| 亚洲七区 | 国产精品久久久久久久久久直播 | 国产一区二区黄 | 成人午夜小视频 | 日韩久久久久久久久 | 一区二区三区免费毛片 | 亚洲国产精品无码专区 | 国产亚洲精品成人 | 丰满的女人性猛交 | 一二三区精品 | 特级毛片爽www免费版 | 大奶子网站 | 五月天激情国产综合婷婷婷 | 国产精品丝袜视频无码一区69 | 麻豆视频免费观看 | 3d动漫精品啪啪一区二区三区免费 | 国产高清在线视频 | 久久伊人一区二区 | 久久黑人| 国产激情无套内精对白视频 | 一级黄色影院 | 国产一区二区视频免费 | 日本一区二区人妻 | 性开放网站 | 日韩理论视频 | 久久无码国产视频 | 欧美综合成人 | 欧美大色网| 拔插拔插华人 | 影音先锋国产在线 | 中文人妻一区二区三区 | 啦啦啦av| 好吊操这里有精品 | 久久久久久久久久久影视 | 国产美女精品视频国产 | 日韩aaaaa| 欧美精品不卡 | 午夜91| 青青在线精品 | 黄色片网战 | 天天插天天摸 | 99精品国产一区 | 视频在线观看电影完整版高清免费 | 日本寂寞少妇 | 黄网址在线观看 | 欧美精品成人久久 | 久久这里都是精品 | 直接看的av网站 | 免费的黄色一级片 | 亚洲成人网在线播放 | 操欧美女 | 重囗另类bbwseⅹhd | 国产精品一区二区入口九绯色 | 日韩av高清在线观看 | 国产第9页 | 日本欧美www | 红桃视频国产精品 | 热热热色 | 日本寂寞少妇 | 黄色特级视频 | 亚洲精品在线视频观看 | 日韩一区二区三区三四区视频在线观看 | 国产精品免费网站 |