#include< bits/ stdc++ .h >
using namespace std;
class ST {
vector< int> seg, lazy;
public :
ST( int n) {
seg.resize ( 4 * n) ;
lazy.resize ( 4 * n) ;
}
public :
void build( int ind, int low, int high, int arr[ ] ) {
if ( low == high) {
seg[ ind] = arr[ low] ;
return ;
}
int mid = ( low + high) >> 1 ;
build( 2 * ind+ 1 , low, mid, arr) ;
build( 2 * ind+ 2 , mid+ 1 , high, arr) ;
seg[ ind] = seg[ 2 * ind+ 1 ] + seg[ 2 * ind+ 2 ] ;
}
public :
void update( int ind, int low, int high, int l, int r,
int val) {
// update the previous remaining updates
// and propogate downwards
if ( lazy[ ind] != 0 ) {
seg[ ind] += ( high - low + 1 ) * lazy[ ind] ;
// propogate the lazy update downwards
// for the remaining nodes to get updated
if ( low != high) {
lazy[ 2 * ind+ 1 ] += lazy[ ind] ;
lazy[ 2 * ind+ 2 ] += lazy[ ind] ;
}
lazy[ ind] = 0 ;
}
// no overlap
// we don't do anything and return
// low high l r or l r low high
if ( high < l or r < low) {
return ;
}
// complete overlap
// l low high r
if ( low>= l && high <= r) {
seg[ ind] += ( high - low + 1 ) * val;
// if a leaf node, it will have childrens
if ( low != high) {
lazy[ 2 * ind+ 1 ] += val;
lazy[ 2 * ind+ 2 ] += val;
}
return ;
}
// last case has to be no overlap case
int mid = ( low + high) >> 1 ;
update( 2 * ind+ 1 , low, mid, l, r, val) ;
update( 2 * ind+ 2 , mid+ 1 , high, l, r, val) ;
seg[ ind] = seg[ 2 * ind+ 1 ] + seg[ 2 * ind+ 2 ] ;
}
public :
int query( int ind, int low, int high, int l, int r) {
// update if any updates are remaining
// as the node will stay fresh and updated
if ( lazy[ ind] != 0 ) {
seg[ ind] += ( high - low + 1 ) * lazy[ ind] ;
// propogate the lazy update downwards
// for the remaining nodes to get updated
if ( low != high) {
lazy[ 2 * ind+ 1 ] += lazy[ ind] ;
lazy[ 2 * ind+ 2 ] += lazy[ ind] ;
}
lazy[ ind] = 0 ;
}
// no overlap return 0;
if ( high < l or r < low) {
return 0 ;
}
// complete overlap
if ( low>= l && high <= r) return seg[ ind] ;
int mid = ( low + high) >> 1 ;
int left = query( 2 * ind+ 1 , low, mid, l, r) ;
int right = query( 2 * ind+ 2 , mid+ 1 , high, l, r) ;
return left + right;
}
} ;
class STMin {
vector< int> seg, lazy;
public :
STMin( int n) {
seg.resize ( 4 * n) ;
lazy.resize ( 4 * n) ;
}
public :
void build( int ind, int low, int high, int arr[ ] ) {
if ( low == high) {
seg[ ind] = arr[ low] ;
return ;
}
int mid = ( low + high) >> 1 ;
build( 2 * ind+ 1 , low, mid, arr) ;
build( 2 * ind+ 2 , mid+ 1 , high, arr) ;
seg[ ind] = min( seg[ 2 * ind+ 1 ] , seg[ 2 * ind+ 2 ] ) ;
}
public :
void update( int ind, int low, int high, int l, int r,
int val) {
// update the previous remaining updates
// and propogate downwards
if ( lazy[ ind] != 0 ) {
seg[ ind] += lazy[ ind] ;
// propogate the lazy update downwards
// for the remaining nodes to get updated
if ( low != high) {
lazy[ 2 * ind+ 1 ] += lazy[ ind] ;
lazy[ 2 * ind+ 2 ] += lazy[ ind] ;
}
lazy[ ind] = 0 ;
}
// no overlap
// we don't do anything and return
// low high l r or l r low high
if ( high < l or r < low) {
return ;
}
// complete overlap
// l low high r
if ( low>= l && high <= r) {
seg[ ind] += val;
// if a leaf node, it will have childrens
if ( low != high) {
lazy[ 2 * ind+ 1 ] += val;
lazy[ 2 * ind+ 2 ] += val;
}
return ;
}
// last case has to be no overlap case
int mid = ( low + high) >> 1 ;
update( 2 * ind+ 1 , low, mid, l, r, val) ;
update( 2 * ind+ 2 , mid+ 1 , high, l, r, val) ;
seg[ ind] = min( seg[ 2 * ind+ 1 ] , seg[ 2 * ind+ 2 ] ) ;
}
public :
int query( int ind, int low, int high, int l, int r) {
// update if any updates are remaining
// as the node will stay fresh and updated
if ( lazy[ ind] != 0 ) {
seg[ ind] += lazy[ ind] ;
// propogate the lazy update downwards
// for the remaining nodes to get updated
if ( low != high) {
lazy[ 2 * ind+ 1 ] += lazy[ ind] ;
lazy[ 2 * ind+ 2 ] += lazy[ ind] ;
}
lazy[ ind] = 0 ;
}
// no overlap return 0;
if ( high < l or r < low) {
return INT_MAX;
}
// complete overlap
if ( low>= l && high <= r) return seg[ ind] ;
int mid = ( low + high) >> 1 ;
int left = query( 2 * ind+ 1 , low, mid, l, r) ;
int right = query( 2 * ind+ 2 , mid+ 1 , high, l, r) ;
return min( left,right) ;
}
} ;
class ST {
vector< int> seg, lazy;
public :
ST( int n) {
seg.resize ( 4 * n) ;
lazy.resize ( 4 * n) ;
}
public :
void build( int ind, int low, int high, int arr[ ] ) {
if ( low == high) {
seg[ ind] = arr[ low] ;
return ;
}
int mid = ( low + high) >> 1 ;
build( 2 * ind+ 1 , low, mid, arr) ;
build( 2 * ind+ 2 , mid+ 1 , high, arr) ;
seg[ ind] = seg[ 2 * ind+ 1 ] + seg[ 2 * ind+ 2 ] ;
}
public :
void update( int ind, int low, int high, int l, int r,
int val) {
// update the previous remaining updates
// and propogate downwards
if ( lazy[ ind] != 0 ) {
seg[ ind] = ( high - low + 1 ) - seg[ ind] ;
// propogate the lazy update downwards
// for the remaining nodes to get updated
if ( low != high) {
lazy[ 2 * ind+ 1 ] = ! lazy[ 2 * ind + 1 ] ;
lazy[ 2 * ind+ 2 ] = ! lazy[ 2 * ind + 2 ] ;
}
lazy[ ind] = 0 ;
}
// no overlap
// we don't do anything and return
// low high l r or l r low high
if ( high < l or r < low) {
return ;
}
// complete overlap
// l low high r
if ( low>= l && high <= r) {
seg[ ind] = ( high - low + 1 ) - val;
// if a leaf node, it will have childrens
if ( low != high) {
lazy[ 2 * ind+ 1 ] = ! lazy[ 2 * ind + 1 ] ;
lazy[ 2 * ind+ 2 ] = ! lazy[ 2 * ind + 2 ] ;
}
return ;
}
// last case has to be no overlap case
int mid = ( low + high) >> 1 ;
update( 2 * ind+ 1 , low, mid, l, r, val) ;
update( 2 * ind+ 2 , mid+ 1 , high, l, r, val) ;
seg[ ind] = seg[ 2 * ind+ 1 ] + seg[ 2 * ind+ 2 ] ;
}
public :
int query( int ind, int low, int high, int l, int r) {
// update if any updates are remaining
// as the node will stay fresh and updated
if ( lazy[ ind] != 0 ) {
seg[ ind] = ( high - low + 1 ) - seg[ ind] ;
// propogate the lazy update downwards
// for the remaining nodes to get updated
if ( low != high) {
lazy[ 2 * ind+ 1 ] = ! lazy[ 2 * ind + 1 ] ;
lazy[ 2 * ind+ 2 ] = ! lazy[ 2 * ind + 2 ] ;
}
lazy[ ind] = 0 ;
}
// no overlap return 0;
if ( high < l or r < low) {
return 0 ;
}
// complete overlap
if ( low>= l && high <= r) return seg[ ind] ;
int mid = ( low + high) >> 1 ;
int left = query( 2 * ind+ 1 , low, mid, l, r) ;
int right = query( 2 * ind+ 2 , mid+ 1 , high, l, r) ;
return left + right;
}
} ;
int main( ) {
#ifndef ONLINE_JUDGE
freopen( "input.txt" , "r" , stdin) ;
freopen( "output.txt" , "w" , stdout) ;
#endif
int n;
cin >> n;
int arr[ n] ;
for ( int i = 0 ; i< n; i++ ) cin >> arr[ i] ;
ST st( n+ 1 ) ;
st.build ( 0 ,0 ,n- 1 , arr) ;
int q;
cin >> q;
while ( q-- ) {
int type;
cin >> type;
if ( type== 1 ) {
int l, r;
cin >> l >> r;
cout << st.query ( 0 ,0 ,n- 1 ,l,r) << endl;
}
else {
int l, r, val;
cin >> l >> r >> val;
st.update ( 0 ,0 ,n- 1 ,l,r,val) ;
}
}
return 0 ;
}
#include<bits/stdc++.h>
using namespace std; 
class ST {
	vector<int> seg, lazy; 
public: 
	ST(int n) {
		seg.resize(4 * n); 
		lazy.resize(4 * n); 
	}
public: 
	void build(int ind, int low, int high, int arr[]) {
		if(low == high) {
			seg[ind] = arr[low];
			return; 
		}
		int mid = (low + high) >> 1; 
		build(2*ind+1, low, mid, arr); 
		build(2*ind+2, mid+1, high, arr); 
		seg[ind] = seg[2*ind+1] + seg[2*ind+2];
	}
public:
	void update(int ind, int low, int high, int l, int r, 
		int val) {
		// update the previous remaining updates 
		// and propogate downwards 
		if(lazy[ind] != 0) {
			seg[ind] += (high - low + 1) * lazy[ind]; 
			// propogate the lazy update downwards
			// for the remaining nodes to get updated 
			if(low != high) {
				lazy[2*ind+1] += lazy[ind]; 
				lazy[2*ind+2] += lazy[ind]; 
			}

			lazy[ind] = 0; 
		}

		// no overlap 
		// we don't do anything and return 
		// low high l r or l r low high 
		if(high < l or r < low) {
			return; 
		}

		// complete overlap 
		// l low high r 
		if(low>=l && high <= r) {
			seg[ind] += (high - low + 1) * val; 
			// if a leaf node, it will have childrens
			if(low != high) {
				lazy[2*ind+1] += val; 
				lazy[2*ind+2] += val; 
			}
			return; 
		}
		// last case has to be no overlap case
		int mid = (low + high) >> 1; 
		update(2*ind+1, low, mid, l, r, val);
		update(2*ind+2, mid+1, high, l, r, val); 
		seg[ind] = seg[2*ind+1] + seg[2*ind+2]; 
	}
public: 
	int query(int ind, int low, int high, int l, int r) {

		// update if any updates are remaining 
		// as the node will stay fresh and updated 
		if(lazy[ind] != 0) {
			seg[ind] += (high - low + 1) * lazy[ind]; 
			// propogate the lazy update downwards
			// for the remaining nodes to get updated 
			if(low != high) {
				lazy[2*ind+1] += lazy[ind]; 
				lazy[2*ind+2] += lazy[ind]; 
			}

			lazy[ind] = 0; 
		}

		// no overlap return 0; 
		if(high < l or r < low) {
			return 0; 
		}

		// complete overlap 
		if(low>=l && high <= r) return seg[ind]; 

		int mid = (low + high) >> 1; 
		int left = query(2*ind+1, low, mid, l, r);
		int right = query(2*ind+2, mid+1, high, l, r);
		return left + right; 
	}
};


class STMin {
	vector<int> seg, lazy; 
public: 
	STMin(int n) {
		seg.resize(4 * n); 
		lazy.resize(4 * n); 
	}
public: 
	void build(int ind, int low, int high, int arr[]) {
		if(low == high) {
			seg[ind] = arr[low];
			return; 
		}
		int mid = (low + high) >> 1; 
		build(2*ind+1, low, mid, arr); 
		build(2*ind+2, mid+1, high, arr); 
		seg[ind] = min(seg[2*ind+1], seg[2*ind+2]);
	}
public:
	void update(int ind, int low, int high, int l, int r, 
		int val) {
		// update the previous remaining updates 
		// and propogate downwards 
		if(lazy[ind] != 0) {
			seg[ind] += lazy[ind]; 
			// propogate the lazy update downwards
			// for the remaining nodes to get updated 
			if(low != high) {
				lazy[2*ind+1] += lazy[ind]; 
				lazy[2*ind+2] += lazy[ind]; 
			}

			lazy[ind] = 0; 
		}

		// no overlap 
		// we don't do anything and return 
		// low high l r or l r low high 
		if(high < l or r < low) {
			return; 
		}

		// complete overlap 
		// l low high r 
		if(low>=l && high <= r) {
			seg[ind] += val; 
			// if a leaf node, it will have childrens
			if(low != high) {
				lazy[2*ind+1] += val; 
				lazy[2*ind+2] += val; 
			}
			return; 
		}
		// last case has to be no overlap case
		int mid = (low + high) >> 1; 
		update(2*ind+1, low, mid, l, r, val);
		update(2*ind+2, mid+1, high, l, r, val); 
		seg[ind] = min(seg[2*ind+1], seg[2*ind+2]); 
	}
public: 
	int query(int ind, int low, int high, int l, int r) {

		// update if any updates are remaining 
		// as the node will stay fresh and updated 
		if(lazy[ind] != 0) {
			seg[ind] += lazy[ind]; 
			// propogate the lazy update downwards
			// for the remaining nodes to get updated 
			if(low != high) {
				lazy[2*ind+1] += lazy[ind]; 
				lazy[2*ind+2] += lazy[ind]; 
			}

			lazy[ind] = 0; 
		}

		// no overlap return 0; 
		if(high < l or r < low) {
			return INT_MAX; 
		}

		// complete overlap 
		if(low>=l && high <= r) return seg[ind]; 

		int mid = (low + high) >> 1; 
		int left = query(2*ind+1, low, mid, l, r);
		int right = query(2*ind+2, mid+1, high, l, r);
		return min(left,right); 
	}
};


class ST {
	vector<int> seg, lazy; 
public: 
	ST(int n) {
		seg.resize(4 * n); 
		lazy.resize(4 * n); 
	}
public: 
	void build(int ind, int low, int high, int arr[]) {
		if(low == high) {
			seg[ind] = arr[low];
			return; 
		}
		int mid = (low + high) >> 1; 
		build(2*ind+1, low, mid, arr); 
		build(2*ind+2, mid+1, high, arr); 
		seg[ind] = seg[2*ind+1] + seg[2*ind+2];
	}
public:
	void update(int ind, int low, int high, int l, int r, 
		int val) {
		// update the previous remaining updates 
		// and propogate downwards 
		if(lazy[ind] != 0) {
			seg[ind] = (high - low + 1) - seg[ind]; 
			// propogate the lazy update downwards
			// for the remaining nodes to get updated 
			if(low != high) {
				lazy[2*ind+1] = !lazy[2*ind + 1]; 
				lazy[2*ind+2] = !lazy[2*ind + 2]; 
			}

			lazy[ind] = 0; 
		}

		// no overlap 
		// we don't do anything and return 
		// low high l r or l r low high 
		if(high < l or r < low) {
			return; 
		}

		// complete overlap 
		// l low high r 
		if(low>=l && high <= r) {
			seg[ind] = (high - low + 1) - val; 
			// if a leaf node, it will have childrens
			if(low != high) {
				lazy[2*ind+1] = !lazy[2*ind + 1]; 
				lazy[2*ind+2] = !lazy[2*ind + 2]; 
			}
			return; 
		}
		// last case has to be no overlap case
		int mid = (low + high) >> 1; 
		update(2*ind+1, low, mid, l, r, val);
		update(2*ind+2, mid+1, high, l, r, val); 
		seg[ind] = seg[2*ind+1] + seg[2*ind+2]; 
	}
public: 
	int query(int ind, int low, int high, int l, int r) {

		// update if any updates are remaining 
		// as the node will stay fresh and updated 
		if(lazy[ind] != 0) {
			seg[ind] = (high - low + 1) - seg[ind]; 
			// propogate the lazy update downwards
			// for the remaining nodes to get updated 
			if(low != high) {
				lazy[2*ind+1] = !lazy[2*ind + 1]; 
				lazy[2*ind+2] = !lazy[2*ind + 2]; 
			}

			lazy[ind] = 0; 
		}

		// no overlap return 0; 
		if(high < l or r < low) {
			return 0; 
		}

		// complete overlap 
		if(low>=l && high <= r) return seg[ind]; 

		int mid = (low + high) >> 1; 
		int left = query(2*ind+1, low, mid, l, r);
		int right = query(2*ind+2, mid+1, high, l, r);
		return left + right; 
	}
};
int main() {
	#ifndef ONLINE_JUDGE
	freopen("input.txt", "r", stdin); 
	freopen("output.txt", "w", stdout); 
	#endif
	int n;
	cin >> n; 
	int arr[n];
	for(int i = 0;i<n;i++) cin >> arr[i]; 
	ST st(n+1); 
	st.build(0,0,n-1, arr); 

	int q;
	cin >> q; 
	while(q--) {
		int type;
		cin >> type; 
		if(type==1) {
			int l, r;
			cin >> l >> r;
			cout << st.query(0,0,n-1,l,r) << endl; 
		}
		else {
			int l, r, val;
			cin >> l >> r >> val; 
			st.update(0,0,n-1,l,r,val);
		}
	}
	return 0; 
}









compilation info
Main.java:1: error: illegal character: '#'
#include<bits/stdc++.h>
^
Main.java:1: error: class, interface, or enum expected
#include<bits/stdc++.h>
^
Main.java:5: error: illegal start of type
public:
^
Main.java:10: error: illegal start of type
public:
^
Main.java:21: error: illegal start of type
public:
^
Main.java:41: error: ')' expected
if(high < l or r < low) {
^
Main.java:41: error: ';' expected
if(high < l or r < low) {
^
Main.java:41: error: variable declaration not allowed here
if(high < l or r < low) {
^
Main.java:41: error: > expected
if(high < l or r < low) {
^
Main.java:62: error: illegal start of type
public:
^
Main.java:80: error: ')' expected
if(high < l or r < low) {
^
Main.java:80: error: ';' expected
if(high < l or r < low) {
^
Main.java:80: error: variable declaration not allowed here
if(high < l or r < low) {
^
Main.java:80: error: > expected
if(high < l or r < low) {
^
Main.java:97: error: illegal start of type
public:
^
Main.java:102: error: illegal start of type
public:
^
Main.java:113: error: illegal start of type
public:
^
Main.java:133: error: ')' expected
if(high < l or r < low) {
^
Main.java:133: error: ';' expected
if(high < l or r < low) {
^
Main.java:133: error: variable declaration not allowed here
if(high < l or r < low) {
^
Main.java:133: error: > expected
if(high < l or r < low) {
^
Main.java:154: error: illegal start of type
public:
^
Main.java:172: error: ')' expected
if(high < l or r < low) {
^
Main.java:172: error: ';' expected
if(high < l or r < low) {
^
Main.java:172: error: variable declaration not allowed here
if(high < l or r < low) {
^
Main.java:172: error: > expected
if(high < l or r < low) {
^
Main.java:189: error: illegal start of type
public:
^
Main.java:194: error: illegal start of type
public:
^
Main.java:205: error: illegal start of type
public:
^
Main.java:225: error: ')' expected
if(high < l or r < low) {
^
Main.java:225: error: ';' expected
if(high < l or r < low) {
^
Main.java:225: error: variable declaration not allowed here
if(high < l or r < low) {
^
Main.java:225: error: > expected
if(high < l or r < low) {
^
Main.java:246: error: illegal start of type
public:
^
Main.java:264: error: ')' expected
if(high < l or r < low) {
^
Main.java:264: error: ';' expected
if(high < l or r < low) {
^
Main.java:264: error: variable declaration not allowed here
if(high < l or r < low) {
^
Main.java:264: error: > expected
if(high < l or r < low) {
^
Main.java:277: error: class, interface, or enum expected
int main() {
^
Main.java:278: error: illegal character: '#'
#ifndef ONLINE_JUDGE
^
Main.java:280: error: class, interface, or enum expected
freopen("output.txt", "w", stdout);
^
Main.java:281: error: illegal character: '#'
#endif
^
Main.java:282: error: class, interface, or enum expected
int n;
^
Main.java:283: error: class, interface, or enum expected
cin >> n;
^
Main.java:284: error: class, interface, or enum expected
int arr[n];
^
Main.java:285: error: class, interface, or enum expected
for(int i = 0;i<n;i++) cin >> arr[i];
^
Main.java:285: error: class, interface, or enum expected
for(int i = 0;i<n;i++) cin >> arr[i];
^
Main.java:285: error: class, interface, or enum expected
for(int i = 0;i<n;i++) cin >> arr[i];
^
Main.java:286: error: class, interface, or enum expected
ST st(n+1);
^
Main.java:287: error: class, interface, or enum expected
st.build(0,0,n-1, arr);
^
Main.java:289: error: class, interface, or enum expected
int q;
^
Main.java:290: error: class, interface, or enum expected
cin >> q;
^
Main.java:291: error: class, interface, or enum expected
while(q--) {
^
Main.java:293: error: class, interface, or enum expected
cin >> type;
^
Main.java:294: error: class, interface, or enum expected
if(type==1) {
^
Main.java:296: error: class, interface, or enum expected
cin >> l >> r;
^
Main.java:297: error: class, interface, or enum expected
cout << st.query(0,0,n-1,l,r) << endl;
^
Main.java:298: error: class, interface, or enum expected
}
^
Main.java:301: error: class, interface, or enum expected
cin >> l >> r >> val;
^
Main.java:302: error: class, interface, or enum expected
st.update(0,0,n-1,l,r,val);
^
Main.java:303: error: class, interface, or enum expected
}
^
Main.java:306: error: class, interface, or enum expected
}
^
62 errors
stdout