LOJ#6281. 數列分塊入門 5

內存限制:256 MiB時間限制:500 ms標準輸入輸出
題目類型:傳統評測方式:文本比較
上傳者:?hzwer
提交提交記錄統計討論
1
測試數據

題目描述

給出一個長為?nnn?的數列,以及?nnn?個操作,操作涉及區間開方,區間求和。

輸入格式

第一行輸入一個數字?nnn。

第二行輸入?nnn?個數字,第 i 個數字為?aia_ia?i??,以空格隔開。

接下來輸入?nnn?行詢問,每行輸入四個數字?opt\mathrm{opt}opt、lll、rrr、ccc,以空格隔開。

若?opt=0\mathrm{opt} = 0opt=0,表示將位于?[l,r][l, r][l,r]?的之間的數字都開方。

若?opt=1\mathrm{opt} = 1opt=1,表示詢問位于?[l,r][l, r][l,r]?的所有數字的和。

輸出格式

對于每次詢問,輸出一行一個數字表示答案。

樣例

樣例輸入

4
1 2 2 3
0 1 3 1
1 1 4 4
0 1 2 2
1 1 2 4

樣例輸出

6
2

數據范圍與提示

對于?100% 100\%100%?的數據,1≤n≤50000,?231≤others 1 \leq n \leq 50000, -2^{31} \leq \mathrm{others}1n50000,?2?31??others、ans≤231?1 \mathrm{ans} \leq 2^{31}-1ans2?31???1。

?

?

這道題的難點在于如何維護開根這個神奇的操作

我自己測的是1e7的數差不多開五六次根就會變成1,所以我們直接維護整個塊內的數是否變成了1就可以了

?

#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<vector>
#define int long long 
using namespace std;
const int MAXN=1e5+10;
const int INF=1e8+10;
inline char nc()
{static char buf[MAXN],*p1=buf,*p2=buf;return p1==p2&&(p2=(p1=buf)+fread(buf,1,MAXN,stdin),p1==p2)?EOF:*p1++;
}
inline int read()
{char c=nc();int x=0,f=1;while(c<'0'||c>'9'){if(c=='-')f=-1;c=nc();}while(c>='0'&&c<='9'){x=x*10+c-'0';c=nc();}return x*f;
}
int N;
int a[MAXN],block,L[MAXN],R[MAXN],belong[MAXN],sum[MAXN],flag[MAXN];void Sqrt(int l,int r)
{for(int i=l;i<=min(r,R[l]);i++){sum[belong[i]]-=a[i];a[i]=sqrt(a[i]);sum[belong[i]]+=a[i];}if(belong[l]!=belong[r])for(int i=L[r];i<=r;i++)sum[belong[i]]-=a[i],a[i]=sqrt(a[i]),sum[belong[i]]+=a[i];for(int i=belong[l]+1;i<=belong[r]-1;i++){if(flag[i]) {continue;}flag[i]=1;for(int j=L[i*block];j<=R[i*block];j++){sum[i]-=a[j];a[j]=sqrt(a[j]);sum[i]+=a[j];if(a[j]>1) flag[i]=0;}}
}
int Query(int l,int r)
{int ans=0;for(int i=l;i<=min(r,R[l]);i++)ans+=a[i];if(belong[l]!=belong[r])for(int i=L[r];i<=r;i++)ans+=a[i];for(int i=belong[l]+1;i<=belong[r]-1;i++)ans+=sum[i];return ans;
}
main()
{#ifdef WIN32freopen("a.in","r",stdin);// freopen("b.out","w",stdout);#else#endifN=read();block=sqrt(N);for(int i=1;i<=N;i++) a[i]=read();for(int i=1;i<=N;i++) belong[i]=(i-1)/block+1,L[i]=(belong[i]-1)*block+1,R[i]=belong[i]*block;for(int i=1;i<=N;i++) sum[belong[i]]+=a[i];for(int i=1;i<=N;i++){int opt=read(),l=read(),r=read(),c=read();if(opt==0) Sqrt(l,r); else  printf("%d\n",Query(l,r));}return 0;
}

  

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/452653.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/452653.shtml
英文地址,請注明出處:http://en.pswp.cn/news/452653.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

版本控制工具歷史的10個里程碑

導讀&#xff1a;作者Eric Raymond在flourish上發表的一篇《Astonishments, ten, in the history of version control》&#xff0c;文中總結了版本控制工具的重要10個里程碑&#xff0c;一起與開發者分享下。 如果你想要了解真正的歷史&#xff0c;你需要回到在打孔卡上進行人…

php把語音轉成幀,[轉載]用TCP/IP實現自己簡單的應用程序協議:成幀器部分

在前面《字節和字符,對信息進行編碼》&#xff0c;《Socket>流&#xff0c;TCP連接,TCP可靠性概述》一系列的隨筆中我們已經表述了相應的理論知識&#xff0c;現在可以動手實現一個自己的應用程序協議。將 數據轉換成在線路上傳輸的字節序列只完成了一半的工作&#xff0c;在…

實體聯系圖簡介

通常&#xff0c;使用實體聯系圖(entity relationship diagram)來建立數據模型。可以把實體聯系圖簡稱為ER圖&#xff0c;相應地可把用ER圖描繪的數據模型稱為ER模型。 ER圖中包含了實體(即數據對象)、關系和屬性3種基本成分&#xff0c;通常用矩形框代表實體&#xff0c;用連…

Flask愛家租房--城區信息

0.效果展示 城市列表使用緩存的過程 1.后端代碼 # coding:utf-8from . import api from flask import g, current_app, jsonify, request, session from ihome.utils.response_code import RET from ihome.models import Area, House, Facility, HouseImage, User, Order from …

數值計算算法-多項式插值算法的實現與分析

數值計算是指在數值分析領域中的算法。數值分析是專門研究和數字以及近似值相關的數據問題&#xff0c;數值計算在數值分析的研究中發揮了特別重要的作用。 多項式插值是計算函數近似值的一種方法。其中函數值僅在幾個點上已知。 該算法的基礎是建立級數小于等于n的一個插值多項…

HIVE ORC 報錯ClassCastException

HIVE ORC格式的表查詢報錯 Failed with exception java.io.IOException:java.lang.ClassCastException: org.apache.hadoop.hive.ql.io.orc.OrcStruct cannot be cast to org.apache.hadoop.io.BinaryComparable 建表語句如下&#xff1a; CREATE EXTERNAL TABLE test_orc( te…

程序型語言VS.編譯型語言

導讀&#xff1a;每日[快訊精選]是由CSDN研發頻道推出的特色欄目&#xff0c;每一天我們將從國外技術媒體(例如Hacker News、Reddit...等等)中挑選出有價值的新聞簡訊&#xff0c;讓您在第一時間掌握業界主流的技術文摘&#xff0c;每天清晨為您獻上第一份技術早餐。 [1]程序型…

ancestral 箭頭符號,譯林版《牛津高中英語》模塊五 高二上學期

《牛津英語》由譯林出版社和牛津大學出版社聯合編寫出版。通過在南京和蘇州開始的試用&#xff0c;取得了非常良好的效果&#xff0c;己在省內全面推廣。有人認為新教材在教育觀念和編排體系上的改革力度是八十年代以來最大的一次。它帶給我們一線教師的沖擊無疑是巨大的。二、…

[NOI2012]騎行川藏

題解&#xff1a; 我發現拉格朗日乘數法真是個好東西。。 我是不會說我數學競賽求最值都是用這個東西的 由于我不太會打那個符號就用li代表通常偏導數中的lanmuda 。。。 這題里化簡一下就可以得到 2 li * ki * ?(vi??vi′?)* vi^2?1 然后一旦li確定 我們會發現這個三次函…

MAC地址和IP地址的關系

簡單地說&#xff1a;ip地址是服務商給你的&#xff0c;mac地址是你的網卡物理地址。 一、IP地址 對于IP地址&#xff0c;相信大家都很熟悉&#xff0c;即指使用TCP/IP協議指定給主機的32位地址。IP地址由用點分隔開的4個8八位組構成&#xff0c;如192.168.0.1就是一個IP地址…

Linux中斷 - tasklet

一、前言 對于中斷處理而言&#xff0c;linux將其分成了兩個部分&#xff0c;一個叫做中斷handler&#xff08;top half&#xff09;&#xff0c;屬于不那么緊急需要處理的事情被推遲執行&#xff0c;我們稱之deferable task&#xff0c;或者叫做bottom half&#xff0c;。具體…

數字電視制播設備間的文件交換格式

在現今的數字電視演播室中&#xff0c;設備之間基本上采用信號流連接方式&#xff0c;如SDI、STDI、模擬YUV、VBS等信號流。在非線性編輯系統和播出系統與服務器之間的連接&#xff0c;還有基于MPEG-2傳輸流等的信號連接方式。基于信號流連接方式的主要特點是&#xff0c;傳送時…

oracle 位移運算符,Oracle“(+)”運算符

在Oracle中&#xff0c;()表示JOIN中的“可選”表。 所以在你的查詢中&#xff0c;select a.id, b.id, a.col_2, b.col_2, ... from a,b where a.idb.id()這是一個左外加B表與一個表。 就像現代的左連接查詢一樣。 (它將返回a表的所有數據&#xff0c;而不會丟失在另一邊的數據…

JAVA-數據類型-復習

JAVA-數據類型-復習 Java中&#xff0c;一共有8種數據類型&#xff0c;4種整型&#xff0c;2種浮點型&#xff0c;1種用于表示Unicode編碼的字符單元的字符類型char&#xff0c;1種布爾類型。 整型 類型存儲需求&#xff08;字節&#xff09;一個字節包含8個位取值范圍byte1-12…

什么是實體-聯系圖(ER圖)

實體-聯系圖&#xff08;ER圖&#xff09;數據模型中包含3種相互關聯的信息&#xff1a;數據對象、數據對象的屬性及數據對象彼此間相互連接的關系。 1.數據對象 數據對象是對軟件必須理解的復合信息的抽象。所謂符合信息是指具有一系列不同性質或屬性的事物&#xff0c;僅有單…

記錄的習慣

記錄的習慣 書籍是人類進步的階梯&#xff0c;承載了人類文明進步的歷程。大多數人都寫過日記&#xff0c;但不知道有多少人重視過日記。常常我們會用相機記錄一些生活中的場景&#xff0c;然后收藏起來&#xff0c;等到若干年后再拿出來看&#xff0c;總能感覺到很溫馨很美好。…

php 去掉實體,用PHP刪除除5個預定義HTML實體之外的所有實體的最佳方法-用于XHTML5輸出...

我目前正在嘗試提供XHTML5.目前,我在正在處理的頁面上提供XHTML 1.1 Strict.那就是我為有能力的瀏覽器所做的.對于那些不接受XML編碼數據的人,我會嚴格遵循HTML4.1.在嘗試使用HTML5進行試驗時,以HTML5格式交付時,所有功能或多或少都可以按預期工作.但是,作為XHTML5交付時,我遇到…

Flask愛家租房--發布新房源(保存房屋基本信息)

0.頁面展示效果 1.后端代碼 api.route("/houses/info", methods["POST"]) login_required def save_house_info():"""保存房屋的基本信息前端發送過來的json數據{"title":"","price":"","ar…

今后最有前途的媒體格式 MXF

MXF格式已經被推出幾年了&#xff0c;從當初一個陌生的不為人們重視的格式逐漸獲得了業內人士的認知和認可&#xff0c;現如今正被廣泛應用于廣播電視與后期制作領域&#xff0c;且有不斷擴大之勢&#xff0c;松下公司推出的基于PII卡的無磁帶式標清攝像機&#xff0c;它所采用…