weight(搜索对象的选取)
题目链接:

就是大概这么个东西
根据题意,我们可以清楚的知道:这个题我不会,这个题需要先将2n个数进行排序
这样每对于一个小的前(后)缀和总会在队列最前或队列最后
设这个数为k
那么判断总的Sum(n)-k是否在集合之中就可以啦
当然,如果不在集合之中,我们就要重新的回溯一遍
直到成功
PS:若k既满足于前缀和又满足于后缀和,先放在前面
因为
下放代码:
//weight
#include <bits/stdc++.h> using namespace std; const int N = ;
int n, s[N], m, a[N], t[N], flag, ans[N], all; inline int read()
{
int x = , y = ;
char z = getchar();
while (z < '' || z > '')
{
if (z == '-')
{
y = -;
z = getchar();
}
}
while (z >= '' && x <= '')
{
x = (x << ) + (x << ) + z - '';
z = getchar();
}
} inline void dfs(int l, int r, int now, int sum1, int sum2)
{
if (flag)
return;
if (l == r)
{
int w3 = all - sum1 - sum2;
if (t[w3])
{
ans[l] = w3;
flag = ;
}
return;
}
int w1 = s[now] - sum1;
if (w1 <= && w1 >= && t[w1]) //属于前缀
{
ans[l] = w1;
dfs(l + , r, now + , s[now], sum2);
}
if (flag)
return;
int w2 = s[now] - sum2;
if (w2 <= && w2 >= && t[w2]) //属于后缀
{
ans[r] = w2;
dfs(l, r - , now + , sum1, s[now]);
}
} int main()
{
scanf("%d", &n);
for (int i = ; i <= * n; i++) //前后缀和
scanf("%d", &s[i]);
scanf("%d", &m);
for (int i = ; i <= m; i++)
{
scanf("%d", &a[i]);
t[a[i]] = ;
}
sort(s + , s + * n + );
all = s[ * n];
dfs(, n, , , );
for (int i = ; i <= n; i++)
printf("%d ", ans[i]);
return ;
}
Fixed on 2020.1.7
emmm,这个好像只能拿90Pts(无所谓了,反正思路差不多)
weight(搜索对象的选取)的更多相关文章
- weight (搜索对象的选取)
#10249. 「一本通 1.3 例 5」weight [题目描述] 已知原数列 $a_1,a_2,\cdots,a_n$ 中的前 1项,前 2 项,前3项, $\cdots$ ,前 n 项的和, ...
- (GoRails)在导航栏增加自动的搜索功能(jquery插件:easyautocomplete)(gem 'ransack' 搜索对象4000✨)
Global Autocomplete Search 需要用到一个JQuery插件和一个搜索对象的gem EasyAutocomplete jQuery插件: https://github.com/p ...
- Java List 快速搜索对象
比如现在有一个需求现在有一个List 里面装Student 对象 我们想找出这个List 对象里面student name=小明的对象 我想很多同学会像以前的我一样变量List 然后去比较 但是这样处 ...
- UVa 11846 - Finding Seats Again
链接: https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...
- OpenCV 学习笔记 06 图像检索以及基于图像描述符的搜索
OpenCV 可以检测图像的主要特征,然后提取这些特征,使其成为图像描述符,这些图像特征可作为图像搜索的数据库:此外可以利用关键点将图像拼接 stitch 起来,组成一个更大的图像.如将各照片组成一个 ...
- whoosh----索引|搜索文本类库
先了解基本概念和步骤: Quick Start Whoosh是一个索引文本和搜索文本的类库,他可以为你提供搜索文本的服务,比如如果你在创建一个博客的软件,你可以用whoosh为它添加添加一个搜索功能以 ...
- Vue+Antd搭配百度地图实现搜索定位等功能
前言 最近,在做vue项目的时候有做到选择地址功能,而原项目中又引入了百度地图,所以我就打算通过使用百度地图来实现地址搜索功能啦. 本次教程可能过于啰嗦,所以这里先放上预览地址供大家预览--点我预览, ...
- 写给程序员的机器学习入门 (十) - 对象识别 Faster-RCNN - 识别人脸位置与是否戴口罩
每次看到大数据人脸识别抓逃犯的新闻我都会感叹技术发展的太快了,国家治安水平也越来越好了
- 4,SFDC 管理员篇 - 数据模型 - 基本对象
Setup | Customize | Object Name | Filed 1, 标准字段定义 standard field:系统字段,不能删除,但是能在页面中remove non-requi ...
随机推荐
- C++基础-多态
本文为 C++ 学习笔记,参考<Sams Teach Yourself C++ in One Hour a Day>第 8 版.<C++ Primer>第 5 版.<代码 ...
- PHP 经典有趣的算法
原文:https://blog.csdn.net/a519395243/article/details/77942913 1.一群猴子排成一圈,按1,2,…,n依次编号.然后从第1只开始数,数到第m只 ...
- HNUSTOJ 1444:树的最长路径
1444: 树的最长路径 时间限制: 1 Sec 内存限制: 128 MB 提交: 18 解决: 7 [提交][状态][讨论版] 题目描述 定义:无向树中结点的路径为该结点所能到达的最远距离:无向 ...
- Python自动化学习--控制浏览器
from selenium import webdriver import time driver = webdriver.Chrome() driver.get("https://www. ...
- [转]0day零距离
前言: 想起这个话题,还要从早年网上的一则新闻说起--"美国联邦官员于2001年12月11日宣布,已破获一起以因特网为犯罪手段的特大软件盗版案--盗版软件的总价值至少高达10亿美元.据悉,该 ...
- Codeforces 954 dijsktra 离散化矩阵快速幂DP 前缀和二分check
A B C D 给你一个联通图 给定S,T 要求你加一条边使得ST的最短距离不会减少 问你有多少种方法 因为N<=1000 所以N^2枚举边数 迪杰斯特拉两次 求出Sdis 和 Tdis 如果d ...
- C#基础知识之dnSpy反编译
dnSpy工具可以在网上自行下载 软件界面如下: 现在进入话题,首先编写一个Hello World的控制台运行程序,如下图所示: 代码如下: using System; using System.Co ...
- C#的Class的几个修饰符
none or internal 类只能在当前的工程中访问 Public 类可以在任何地方访问 abstract or internal abstract ...
- RestTemplate 超级严重BUG之 restTemplate.getForEntity对于下载文件的地址请求 header不起作用
错误下载:RestTemplate restTemplate=new RestTemplate();HttpHeaders httpHeaders=new HttpHeaders();httpHead ...
- 路径path知识点
1. 获取当前文件的路径 test.py os.path.abspath(path) # 返回当前文件运行的绝对路径 print("程序的绝对路径是",os.path.abspat ...