当前位置: 首页 > news >正文

怎么推广我的网站吗做追星网站效果图

怎么推广我的网站吗,做追星网站效果图,十大房产中介软件,广告投放平台有哪些题目链接: D - 1D Country (atcoder.jp) 题目描述: 数据范围: 输入输出: 题目分析: 典型的l, r 区间问题,即是前缀和问题,但是注意到数据范围, 数据范围1e-9 到 1e9 数据范围,要是从最小到最大直接for循环去模拟的话,时间复杂度…

题目链接:

D - 1D Country (atcoder.jp)

题目描述:

数据范围:

输入输出:

题目分析:

典型的l, r 区间问题,即是前缀和问题,但是注意到数据范围, 数据范围1e-9 到 1e9 数据范围,要是从最小到最大直接for循环去模拟的话,时间复杂度太高了O(2e9),注意到极限总共才2e5个居民,要去想到映射,不在关心他们的位置,而去把下标转换为从1开始的,然后在询问l, r这段区间的时候二分去查到对应的l, r他们映射后的位置,然后用前缀和公式sum[映射后的r] - sum[映射后的l - 1]就是最后的答案,但是我用map去写的时候卡到了最后一个数据,但是用数组就过掉了,why?

最后一个数据没过的代码:

#include<bits/stdc++.h>
#define int long long using namespace std;const int N = 2e5 + 10;map<int, int>mp, ren, sum;
//map<int, int>ren;
int a[N];signed main() {int n, m;cin >> n;for(int i = 1; i <= n; i ++ ) {cin >> a[i];}for(int i = 1; i <= n; i ++ ) {int x;cin >> x;mp[a[i]] += x;}
//	sort(a + 1, a + n + 1);//a[0] = 0;
//	sum[a[1] - 1] = 0;sum[a[1]] = mp[a[1]];for(int i = 2; i <= n; i ++ ) {sum[a[i]] = sum[a[i - 1]] + mp[a[i]]; }
//	for(int i = 1; i <= n; i ++ ) {
//		cout << "a[i] = " << a[i] << " sum = " << sum[a[i]] << endl;
//	}cin >> m;// 二分的是位置 while(m -- ) {int l, r;cin >> l >> r;// 二分第一个大于等于l的位置int ll = 0, rr = n + 1;while(ll + 1 < rr) {int mid = ll + rr >> 1;if(a[mid] < l) ll = mid;else rr = mid;}int st = ll + 1;//	cout << "st = " << st << endl;// 二分最后一个小于等于r的位置 ll = 0, rr = n + 1;while(ll + 1 < rr) {int mid = ll + rr >> 1;if(a[mid] <= r)ll = mid;else rr = mid;}int en = ll;if(r > a[n]) {en = n;}if(l < a[1]) {st = 1;}
//		cout << "st - 1 = " << st - 1 << endl;
//		cout << "a[st - 1] = " << a[st - 1] << endl;
//		cout << "en = " << en << endl;
//		cout << "sumEnd = " << sum[a[en]] << endl;
//		cout << "sumStart = " << sum[a[st - 1]] << endl;if(st == 1) {cout << sum[a[en]] << endl;} else {cout << sum[a[en]] - sum[a[st - 1]] << endl;}}return 0;
}
/*
7
-10 -5 -3 -1 0 1 4
2 5 6 5 2 1 7
1
-10 -4*/

运行结果:

 

正确代码:

#include<bits/stdc++.h>
#define int long long using namespace std;const int N = 2e5 + 10;int a[N], sum[N];signed main() {int n, m;cin >> n;for(int i = 1; i <= n; i ++ ) {cin >> a[i];}for(int i = 1; i <= n; i ++ ) {int x;cin >> x;sum[i] = sum[i - 1] + x;}cin >> m;// 二分的是位置 while(m -- ) {int l, r;cin >> l >> r;// 二分第一个大于等于l的位置int ll = 0, rr = n + 1;while(ll + 1 < rr) {int mid = ll + rr >> 1;if(a[mid] < l) ll = mid;else rr = mid;}int st = ll + 1;//	cout << "st = " << st << endl;// 二分最后一个小于等于r的位置 ll = 0, rr = n + 1;while(ll + 1 < rr) {int mid = ll + rr >> 1;if(a[mid] <= r)ll = mid;else rr = mid;}int en = ll;cout << sum[en] - sum[st - 1] << endl;		}return 0;
}

运行结果:

http://www.yayakq.cn/news/703633/

相关文章:

  • 网站已改版如何构建网站
  • 建网站业务员手机网站样例
  • 用dw自己做网站百度大全
  • wordpress模板设计网站seo外链接
  • 金融网站的设计seo 网站结构调整
  • ppt可以做网站吗重庆建站网站免费
  • 网站建设怎么推广放心营销网站开发
  • html前端网站开发国内专业网站建设
  • 网站建设品牌营销做网站如何突出网站特色
  • 阿里云购买网站登录网站被攻击如何处理
  • 上海建设局网站网站开发设计定制
  • 网站用什么格式的图片格式电影网站盗链怎么做
  • 鹤壁网站建设公司3d动画制作流程
  • 新闻类网站建设网站建设模板是什么意思
  • 网站需要兼容哪些浏览器江西网站开发软件公司
  • 新的网站平台如何做地推网站内容有什么特点
  • 合肥网站制作报apache wordpress配置文件
  • 网站的维护和推广wordpress手机端和pc端兼容
  • 二级域名怎么指向另外一个网站做机械设备类网站用什么颜色好
  • 成都高新区建设厅网站盐步网站制作
  • 柳江网站虚拟主机公司网页设计软件html
  • soho做网站多少钱西安网站群搭建
  • 推广网站的广告怎样做可画在线设计平台
  • cod单页建站工具光纤网络是哪个公司的
  • 网站建站的类型视频直播服务
  • 安徽省建设厅官方网站各处室巴市建网站
  • 百度网站推广费用沙发网站建设
  • 做一个简单网站营销型网站的例子
  • 网站之前没备案wordpress通知评论者
  • 哈尔滨大型网站建设免费的汽车网站源码