結果

問題 No.1099 Range Square Sum
ユーザー zyzzyhzyzzyh
提出日時 2024-11-20 09:43:13
言語 C++14
(gcc 12.3.0 + boost 1.83.0)
結果
WA  
実行時間 -
コード長 1,592 bytes
コンパイル時間 2,190 ms
コンパイル使用メモリ 173,328 KB
実行使用メモリ 10,240 KB
最終ジャッジ日時 2024-11-20 09:43:20
合計ジャッジ時間 6,194 ms
ジャッジサーバーID
(参考情報)
judge3 / judge4
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 4 ms
9,728 KB
testcase_01 AC 4 ms
9,600 KB
testcase_02 AC 4 ms
9,600 KB
testcase_03 AC 6 ms
9,600 KB
testcase_04 AC 6 ms
9,728 KB
testcase_05 AC 4 ms
9,472 KB
testcase_06 AC 4 ms
9,600 KB
testcase_07 AC 4 ms
9,728 KB
testcase_08 AC 4 ms
9,472 KB
testcase_09 AC 4 ms
9,728 KB
testcase_10 AC 5 ms
9,728 KB
testcase_11 WA -
testcase_12 AC 5 ms
9,728 KB
testcase_13 AC 5 ms
9,728 KB
testcase_14 AC 6 ms
9,728 KB
testcase_15 AC 5 ms
9,728 KB
testcase_16 AC 5 ms
9,600 KB
testcase_17 AC 5 ms
9,728 KB
testcase_18 WA -
testcase_19 AC 5 ms
9,600 KB
testcase_20 AC 5 ms
9,728 KB
testcase_21 RE -
testcase_22 RE -
testcase_23 RE -
testcase_24 RE -
testcase_25 RE -
testcase_26 RE -
testcase_27 RE -
testcase_28 RE -
testcase_29 RE -
testcase_30 RE -
権限があれば一括ダウンロードができます

ソースコード

diff #

#include<bits/stdc++.h>
using namespace std;
#define int long long
const int N = 1e5+100,mod=1e9+7;
int n,m;
int a[N];
struct dat
{
	int x,y;
	dat(){x=y=0;}
	inline void operator()(const int add,const int len)
	{
		x=(x+add*y%mod*2+len*add%mod*add%mod)%mod;
		y=(y+add*len)%mod;
	}
	inline dat operator+(const dat z)const
	{
		dat res;
		res.x=(x+z.x)%mod,res.y=(y+z.y)%mod;
		return res;
	}
};
namespace sg
{
	#define mid ((l+r)>>1)
	#define ll (x<<1)
	#define rr (x<<1|1)
	#define xx (t[x])
	dat t[N*4];
	int ad[N*4];
	void build(int l,int r,int x)
	{
		if(l==r){cin>>t[x].y;t[x].x=t[x].y*t[x].y%mod;return;}
		build(l,mid,ll),build(mid+1,r,rr);
		t[x]=t[ll]+t[rr];
	}
	inline void add(const int l1,const int r1,int l,int r,int x,const int val)
	{
		if(l>=l1&&r<=r1){ad[x]=(ad[x]+val)%mod;t[x](val,r-l+1);return;}
		if(l1<=mid)add(l1,r1,l,mid,ll,val);
		if(r1>mid)add(l1,r1,mid+1,r,rr,val);
		t[x]=t[ll]+t[rr];
		t[x](ad[x],r-l+1);
	}
	inline dat get(const int l1,const int r1,int l,int r,int x)
	{
		if(l>=l1&&r<=r1)return t[x];
		dat res;
		if(l1<=mid)res=res+get(l1,r1,l,mid,ll);
		if(r1>mid)res=res+get(l1,r1,mid+1,r,rr);
		res(ad[x],min(r,r1)-max(l,l1)+1);
		return res;
	}
}
using namespace sg;
signed main()
{
	ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
	cin>>n;
	build(1,n,1);
	cin>>m;
	char op;
	int l,r,x;
	while(m--)
	{
		cin>>op;
		if(op=='2')
		{
			cin>>l>>r;
			cout<<get(l,r,1,n,1).x<<'\n';
		}
		else
		{
			cin>>l>>r>>x;
			add(l,r,1,n,1,x);
		}
	}
	// int x,y,z;
	// cin>>x>>y>>z;
	// dat res;
	// res.x=x*x+y*y+z*z;
	// res.y=x+y+z;
	// res(3,3);
	// cerr<<res.x;
}
0