B 划分
就是前 的数的和
写个前缀和记录一下即可。
#include<bits/stdc++.h> #include<unordered_map> #pragma GCC optimize(2) #pragma GCC optimize(3) #pragma GCC optimize("Ofast") #pragma GCC target("avx,avx2,fma") #pragma GCC optimization("unroll-loops") using namespace std; #define IOS ios::sync_with_stdio(false);cin.tie(0);cout.tie(0); #define ll long long #define ull unsigned long long #define rint register int #define ld long double #define db double #define rep(i, l, r) for (rint i = l; i <= r; i++) #define rep1(i,a,n) for (rint i=a;i<n;i++) #define per(i, l, r) for (rint i = l; i >= r; i--) #define per1(i,a,n) for (rint i=a;i>n;i--) #define mset(s, _) memset(s, _, sizeof(s)) #define pb push_back #define pii pair <int, int> #define mp(a, b) make_pair(a, b) #define sd(x) scanf("%d",&(x)) #define slld(x) scanf("%lld",&(x)) #define sdd(x,y) scanf("%d%d",&(x),&(y)) #define sc(s) scanf("%s",(s)) #define pd(x) printf("%d\n",(x)) #define plld(x) printf("%lld\n",(x)) #define pdk(x) printf("%d ",(x)) const int inf=0x3f3f3f3f; namespace IO{ char ibuf[1<<21],*ip=ibuf,*ip_=ibuf; char obuf[1<<21],*op=obuf,*op_=obuf+(1<<21); inline char gc(){ if(ip!=ip_)return *ip++; ip=ibuf;ip_=ip+fread(ibuf,1,1<<21,stdin); return ip==ip_?EOF:*ip++; } inline void pc(char c){ if(op==op_)fwrite(obuf,1,1<<21,stdout),op=obuf; *op++=c; } inline ll read(){ register ll x=0,ch=gc(),w=1; for(;ch<'0'||ch>'9';ch=gc())if(ch=='-')w=-1; for(;ch>='0'&&ch<='9';ch=gc())x=x*10+ch-48; return w*x; } template<class I> inline void write(I x){ if(x<0)pc('-'),x=-x; if(x>9)write(x/10);pc(x%10+'0'); } class flusher_{ public: ~flusher_(){if(op!=obuf)fwrite(obuf,1,op-obuf,stdout);} }IO_flusher; } using namespace IO; const int N=1e5+10; ll n,a[N],x,y,b[N],ans; int main() { n=read(); rep(i, 1, n) a[i]=read(); x=read();y=read(); sort(a+1,a+1+n,greater<int>()); rep(i, 1, n) b[i]=b[i-1]+a[i]; rep(i, 1, x){ rep(j, 1, y){ ans+=b[i*j]; } } write(ans); return 0; }