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

行业网站建站搞笑网站建设目的和意义

行业网站建站,搞笑网站建设目的和意义,沈阳顺天建设集团网站,网站建设运营维护方案一、题目 1、题目描述 2、输入输出 2.1输入 2.2输出 3、原题链接 Problem - 1461D - Codeforces 二、解题报告 1、思路分析 我们发现每次分裂操作结果都是固定的 我们从初始序列分裂出两个确定的子序列,两个确定的子序列又分裂出4个确定的子序列 那么也就是说…

一、题目

1、题目描述

2、输入输出

2.1输入

2.2输出

3、原题链接

Problem - 1461D - Codeforces


二、解题报告

1、思路分析

我们发现每次分裂操作结果都是固定的

我们从初始序列分裂出两个确定的子序列,两个确定的子序列又分裂出4个确定的子序列

那么也就是说我们最终能够分裂出的子序列的数目是O(n)的

我们预处理出所有的子序列就预处理出了所有可以得到的和(当然这个和要在分裂的过程中维护)

而分裂要求我们得到小于等于mid的部分和大于的部分

所以我们需要对原序列进行排序,模拟的过程通过二分来找到分裂的位置

同时预处理前缀和以便每次分裂前都记录一下当前得到的值

值得注意的是nums[l] = nums[r]的时候说明当前子序列是相同的,我们无法继续向下分裂

2、复杂度

时间复杂度: O(NlogN)空间复杂度:O(N)

3、代码详解

#include <bits/stdc++.h>
using PII = std::pair<int, int>;
using i64 = long long;
std::mt19937 rnd(std::chrono::steady_clock::now().time_since_epoch().count());const int P = [](int x) {auto isprime = [](int x) {if (x <= 1) return false;for (int i = 2; i <= x / i; i ++ )if (x % i == 0) return false;return true;};while (!isprime(x)) x ++;return x;
}(rnd() % 900000000 + 100000000);void solve() {/*  直接模拟    */int N, Q, s;std::cin >> N >> Q;std::vector<int> nums(N);std::vector<i64> pre(N + 1);for (int i = 0; i < N; i ++ ) std::cin >> nums[i];std::sort(nums.begin(), nums.end());for (int i = 0; i < N; i ++ ) pre[i + 1] += nums[i] + pre[i];std::vector<std::array<int, 2>> segs { { 0, N - 1 } };  segs.reserve(N);std::unordered_set<i64> st;while (segs.size()) {std::vector<std::array<int, 2>> nxt;for (auto& [l, r] : segs) {st.insert(pre[r + 1] - pre[l] + P);if (nums[l] != nums[r]) {int mid = std::upper_bound(nums.begin(), nums.end(), (nums[l] + nums[r]) >> 1) - nums.begin();nxt.insert(nxt.end(), { { l, mid - 1 }, { mid, r } });}}segs = std::move(nxt);}for (int i = 0, s; i < Q; i ++) {std::cin >> s;if (st.count(1LL * s + P))std::cout << "YES\n";elsestd::cout << "NO\n";}
}int main () {std::ios::sync_with_stdio(false);   std::cin.tie(0);  std::cout.tie(0);int _ = 1;std::cin >> _;while (_ --)solve();return 0;
}

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

相关文章:

  • 陕西省建设资格注册中心网站电脑安装什么版本wordpress
  • 阳江营销网站开发江苏工程建设交易信息网站
  • 电子网站建设方案商河做网站公司
  • 网站制作变量网站关键词可以修改吗
  • 腾讯网站认证上海浦东新区做网站
  • 企业网站建设itcask永久免费的移动建站平台
  • 南通市通州建设局网站如何查询网站域名备案信息
  • 网站广告代码宝安设计网站建设
  • 做二手网站好的名字用wordpress做小程序
  • 江阴规划建设局网站临河 网站建设
  • 深圳网站建设公司fantodo南宁seo全网营销
  • 怎么样建设自己网站怎么做自己的网站赚钱
  • 网站推广模板网站开发工具 哪个好
  • 广州货运网站建设动漫制作技术和动漫设计
  • 建设银行联号查询网站北京单位网站建设培训
  • 音乐网站建设课的期末报告书阿里云可以建设网站吗
  • 家具网站素材怎么做网站何做网站
  • 中山专业门户网站制作咨询凡科网站内容怎么做效果好
  • 定远网站开发室内设计师联盟app
  • 昆明网站建设建站技巧外包的工作值得做吗
  • 企业手机网站建设案例shanxi建设银行网站首页
  • 惠州建设公司网站类似钉钉的企业管理软件
  • 网站页面图片尺寸手机网站建设报价多少
  • 德州市经济开发区建设局网站设计官网的
  • 坑梓做网站长沙宁乡建设网站
  • 有关企业电子网站建设论文上海做网站定制
  • 用asp做网站登录页面网站建设技术发展趋势预测
  • 黑龙江省城乡和住房建设厅网站宁津 做网站
  • 关于水果的网站建设手机网站开发协议
  • 教育网站建设网站html5网站源代码