热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

开发笔记:题解P1286两数之和

本文由编程笔记#小编为大家整理,主要介绍了题解P1286两数之和相关的知识,希望对你有一定的参考价值。提供一个新思路这题,我们假设n个数分别为a1
本文由编程笔记#小编为大家整理,主要介绍了题解 P1286 两数之和相关的知识,希望对你有一定的参考价值。



提供一个新思路

这题,我们假设n个数分别为a1,a2,a3,a4,a5...an,且对于任意

1<=i

而他们两两之和即为输入的各数字,从中,我们不难推出对于输入的数字中(我们把它们按从小到大排序,分别设为m1,m2...)

一定满足:m1=a1+a2,m2=a1+a3(我们可以用反证法证明结论)

但m3有两种情况:m3=a1+a4或者m3=a2+a3,我们无法判断,那么,


为什么我们不能把a2+a3的情况排除呢?

所以我们可以这样做: 同样枚举a1(1->m1/2),然后算出a2,a3。这时,我们对a2+a3的数字打个标记,当下次访问到的时候将标记取消说明剩下的数字不是a2+a3,那么,剩下的数的最小的那一个一定是a1+a4!同理我们对a2+a4,a3+a4打标记。。。 最后就能求出所有的a了,如果我们求完了n个数,然而,还有数没被打上标记,就说明此时的a1时错误的我们需要重新枚举。

最后,我们就可以求出答案了~

代码:

#pragma GCC optimize(3)//手动Ox优化
#include
using namespace std;
const int N=1e5+2;
int a[N],tot;
int biao[N],maxe;
int ans[N];
bool F=0;
int n;
inline void print(){//输出答案
for(int i=1;i<=n;++i){
printf("%d ",ans[i]);
}
putchar(
‘);
}
inline void dfs(int x){
memset(biao,0,sizeof(biao));
ans[1]=x,ans[2]=a[1]-x,ans[3]=a[2]-x;
biao[ans[2]+ans[3]]++;//标记记得用int,因为可能存在两组数之和相等的情况
int zhi=4;
F=1;//假设这次是正确的
for(int i=3;i<=tot;++i){
if(biao[a[i]]){
biao[a[i]]--;
continue;
}
ans[zhi++]=a[i]-x;
if(zhi>n+1){
F=0;//本次答案错误
return;
}
for(int j=2;j-1;++j){
if(ans[zhi-1]+ans[j]>maxe){//如果和大于最大值,肯定错误,跳过
F=0;//本次答案错误
return;
}
biao[ans[zhi-1]+ans[j]]++;//打上标记
}
}
}
int main(){
while(~scanf("%d",&n)){
tot=n*(n-1)/2,maxe=0;
for(int i=1;i<=tot;++i){
scanf("%d",&a[i]);
maxe=maxe>a[i]?maxe:a[i];//求最大值
}
sort(a+1,a+tot+1);//排个序~
bool flag=0;
for(int i=1;i<=a[1]/2;++i){
dfs(i);
if(F){
flag=1,F=0;//找到正确答案,F记得清零
print();//输出
break;
}
}
if(!flag){
printf("Impossible
");
continue;
}
}
return 0;
}
/**
*  ┏┓   ┏┓+ +
* ┏┛┻━━━┛┻┓ + +
* ┃       ┃
* ┃   ━   ┃ ++ + + +
* ████━████+
* ◥██◤ ◥██◤ +
* ┃   ┻   ┃
* ┃       ┃ + +
* ┗━┓   ┏━┛
*   ┃   ┃ + + + +Code is far away from  
*   ┃   ┃ + bug with the animal protecting
*   ┃    ┗━━━┓ 神兽保佑,代码无bug 
*   ┃        ┣┓
*   ┃        ┏┛
*  ┗┓┓┏━┳┓┏┛ + + + +
*    ┃┫┫ ┃┫┫
*    ┗┻┛ ┗┻┛+ + + +
*/

推荐阅读
  • 本文深入探讨了UNIX/Linux系统中的进程间通信(IPC)机制,包括消息传递、同步和共享内存等。详细介绍了管道(Pipe)、有名管道(FIFO)、Posix和System V消息队列、互斥锁与条件变量、读写锁、信号量以及共享内存的使用方法和应用场景。 ... [详细]
  • 主调|大侠_重温C++ ... [详细]
  • 本文详细介绍了C语言中的基本数据类型,包括整型、浮点型、字符型及其各自的子类型,并探讨了这些类型在不同编译环境下的表现。 ... [详细]
  • HDU 2871 内存管理问题(线段树优化)
    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2871。本题涉及内存管理操作,包括重置、申请、释放和查询内存块。通过使用线段树进行高效管理和维护。 ... [详细]
  • KMP算法是处理字符串匹配的一种高效算法它首先用O(m)的时间对模板进行预处理,然后用O(n)的时间完成匹配。从渐进的意义上说,这样时间复 ... [详细]
  • 本文介绍了一个经典的算法问题——活动选择问题,来源于牛客网的比赛题目。该问题要求从一系列活动集合中选出最多数量的相容活动,确保这些活动的时间段不重叠。 ... [详细]
  • KMP算法是一种高效的字符串模式匹配算法,能够在不进行回溯的情况下完成匹配,其时间复杂度为O(m+n),其中m和n分别为文本串和模式串的长度。本文将详细介绍KMP算法的工作原理,并提供C语言实现。 ... [详细]
  • 本文详细解析了2019年西安邀请赛中的一道树形动态规划题目——J题《And And And》。题目要求计算树中所有子路径异或值为0的集合数量,通过深入分析和算法优化,提供了高效的解决方案。 ... [详细]
  • 传送门A-Registration#include#definelllonglongusingnamespacestd;chars[15],t[15]; ... [详细]
  • 本文详细介绍了Linux内核中misc设备驱动框架的实现原理及应用方法,包括misc设备的基本概念、驱动框架的初始化过程、数据结构分析以及设备的注册与注销流程。 ... [详细]
  • QNX 微内核(procnto-instr)的监测版本内置了高级跟踪与分析工具,能够实现实时系统监控。该模块适用于单处理器及多处理器系统。 ... [详细]
  • 本文介绍了一个项目中如何在Windows平台上实现多声道音频数据的采集,特别是针对DANTE音频接口的8路立体声音频通道。文章详细描述了使用Windows底层音频API进行音频采集的方法,并提供了一个具体的实现示例。 ... [详细]
  • Description“第一分钟,X说,要有矩阵,于是便有了一个里面写满了\(0\)的\(n\timesm\)矩阵。第二分钟,L说,要能修改,于是便有了将左上角为\((a,b)\) ... [详细]
  • 本文介绍了如何计算给定数组中所有非质数元素的总和,并提供了多种编程语言的实现示例。 ... [详细]
  • 本题探讨了一个生物链模型,其中每个生物 x 可以捕食 x+n 的生物,而 x+n 又捕食 x+2*n 的生物,形成一个循环的食物链。当 x 捕食 y 时,y 和 x+n 会被归类到同一个集合中,同样地,x 也会被归入 y+2*n 所在的集合。 ... [详细]
author-avatar
相对论!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有