国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學院 > 開發設計 > 正文

CF 776C Molly's Chemicals 前綴和,STL

2019-11-06 06:10:18
字體:
來源:轉載
供稿:網友

題目鏈接:見這里 題意:給出n個數,和一個數k,現在問你有多少個區間和等于k的x次方,x從0到無窮 解法:先求出前綴和,也就是求有多少個sum[r]-sum[l]=pow(k,x),r>l。x最大只有lg(1e14),可以將式子變為sum[r]-pow(k,x)=sum[l]。每次結束后將前綴和放到map里。

//CF 776C#include <bits/stdc++.h>using namespace std;const long long inf = 1e14;int n;long long k, sum[100050];map <long long , long long > mp;set <long long> s;int main(){ scanf("%d%lld", &n, &k); mp.clear(); s.clear(); sum[0] = 0; for(int i = 1; i <= n; i++) scanf("%lld", &sum[i]), sum[i] += sum[i-1]; s.insert(1); long long now = k; for(int i = 1; i <= 60; i++){if(now > inf) break; s.insert(now); now *= k;} long long ans = 0; mp[0] = 1; for(int i = 1; i <= n; i++){ for(set<long long>::iterator it = s.begin(); it != s.end(); it++) ans += mp[sum[i] - *it]; mp[sum[i]]++; }
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 邹城市| 鄄城县| 岢岚县| 喀什市| 宁海县| 攀枝花市| 冕宁县| 宿迁市| 会理县| 商水县| 龙川县| 瑞金市| 庐江县| 赤峰市| 河西区| 揭西县| 肃宁县| 景东| 青阳县| 额敏县| 洛隆县| 古丈县| 深州市| 宁城县| 陵川县| 平湖市| 东明县| 桂阳县| 盐边县| 本溪| 哈尔滨市| 双牌县| 濮阳县| 东乡县| 高清| 新泰市| 德州市| 镇雄县| 辽宁省| 秀山| 游戏|