对于给定的整数集合S,求出最大的d,使得a+b+c=d。
对于给定的整数集合S,求出最大的d,使得a+b+c=d。a,b,c,d互不相同,且都属于S。集合的元素个数小于等于2000个,元素的取值范围在[-2^28,2^28 - 1],假定可用内存空间为100MB,硬盘使用空间无限大,试分析时间和空间复杂度,找出最快的解决方法。
提示:两两相加转为多项式乘法,比如(1 2 4 6) + (2 3 4 5) => (x + x^2 + x^4 + x^6)*(x^2 + x^3 + x^4 + x^5) 。
#include <iostream>
#include<map>
#include "bitmap.h"
using namespace std;
#define M (1024*1024*512)
#define N 2000
multimap<int, int> mmp;
void printBitmap(int n) {
for (int i = 0; i < n; ++i) {
if (test(i)) {
cout << i << ' ';
}
}
cout << endl;
}
void printMutimap() {
multimap<int, int>::iterator i, iend;
iend = mmp.end();
for (i = mmp.begin(); i != iend; i++) {
cout << (*i).first << ' ' << (*i).second << endl;
}
}
int* initRandom(int len, int range) {
int* randoms = new int[len];
srand(unsigned(time(0)));
for (int i = 0; i < len; i++) {
randoms[i] = rand() % range;
}
return randoms;
}
void printArray(int* arr, int len) {
cout << "数组:" << endl;
for (int i = 0; i < len; ++i) {
cout << arr[i] << ' ';
}
cout << endl;
}
/*求出集合中每2个数的和,并用bitmap存储,
* multimap里边的key为2个数的和,value值为较小的数,则另一个值为key-value*/
void enumSum(int*arr, int len) {
for (int i = 1; i < len; ++i) {
if (arr[i - 1] != arr[i])
for (int j = i; j < len; ++j) {
//arr[i - 1] != arr[j]和的2个数必须不同
if (arr[j - 1] != arr[j] && arr[i - 1] != arr[j]) {
int sum = arr[i - 1] + arr[j];
// set(sum);
mmp.insert(make_pair(sum, arr[i - 1]));
}
}
}
}
int* enumSub(int* arr, int len) {
typedef multimap<int, int>::size_type sz_type;
for (int i = len - 1; i >= 0; --i) {
for (int j = i - 1; j >= 0; --j) {
if (arr[i] != arr[j]) {
int sub = arr[i] - arr[j];
// if (test(sub)) {
sz_type entries = mmp.count(sub);
if (entries == 0) {
continue;
} else {
multimap<int, int>::iterator iter = mmp.find(sub);
for (sz_type cnt = 0; cnt != entries; ++cnt, ++iter) {
if (iter->second == arr[i]
|| iter->second == arr[j]) {
continue;
} else if (iter->first - iter->second == arr[i]
|| iter->first - iter->second == arr[j]) {
continue;
}
/*M区间[-2^28,2^28 - 1],所以正式结果必须减去(2^28-1)*/
int* result = new int[4];
result[0] = iter->first - iter->second;
result[1] = iter->second;
result[2] = arr[j];
result[3] = arr[i];
return result;
}
}
// }
}
}
}
return NULL;
}
int main() {
bitmap = new int[M / 32]; //M / 32
memset(bitmap, 0, M / 32 * sizeof(int)); //M * sizeof(int)
int* arr = initRandom(N, M);
sort(arr, arr + N);
// printArray(arr, N);
clock_t start_time = clock();
enumSum(arr, N);
/*printBitmap(N);
printMutimap();
*/
// enumSub(arr, N);
int* result = enumSub(arr, N);
if (result) {
cout << result[0] << '+' << result[1] << '+' << result[2] << '='
<< result[3] << endl;
}
clock_t end_time = clock();
cout << "Running time is: "
<< static_cast<double>(end_time - start_time) / CLOCKS_PER_SEC
* 1000 << "ms" << endl; //输出运行时间
return 0;
}
对于给定的整数集合S,求出最大的d,使得a+b+c=d。的更多相关文章
- 已知w是一个大于10但不大于1000000的无符号整数,若w是n(n≥2)位的整数,则求出w的后n-1位的数。
描述 已知w是一个大于10但不大于1000000的无符号整数,若w是n(n≥2)位的整数,则求出w的后n-1位的数. 输入 第一行为M,表示测试数据组数.接下来M行,每行包含一个测试数据. 输出 ...
- 2018.3.12 Leecode习题 给定一个整数数列,找出其中和为特定值的那两个数。
给定一个整数数列,找出其中和为特定值的那两个数. 你可以假设每个输入都只会有一种答案,同样的元素不能被重用. 示例: 给定 nums = [2, 7, 11, 15], target = 9; 因为 ...
- 作业帮:给定一个整数数组,找出其中两个数相加等于目标值(去重set)
题目描述 给定一个整数数组,找出其中两个数相加等于目标值 输入 [1,3,5,7,9,11] 10 输出 1,9 3,7 代码: import java.util.HashMap; import ja ...
- 给定一个整数N,找出一个比N大且最接近N,但二进制权值与该整数相同 的数
1,问题描述 给定一个整数N,该整数的二进制权值定义如下:将该整数N转化成二进制表示法,其中 1 的个数即为它的二进制权值. 比如:十进制数1717 的二进制表示为:0000 0110 1011 01 ...
- codevs:1462 素数和:给定2个整数a,b 求出它们之间(不含a,b)所有质数的和。
#include<iostream>#include<cstdio>#include<cmath>using namespace std;int main(){ i ...
- 编写一个应用程序,利用数组或者集合, 求出"HELLO",“JAVA”,“PROGRAM”,“EXCEPTION”四个字符串的平均长度以及字符出现重复次数最多的字符串。
public class Number { public static void main(String[] args) { String[] arr = { "HELLO", & ...
- 如何求出数组中最小(或者最大)的k个数(least k问题)
输入n个整数,如何求出其中最小的k个数? 解法1. 当然最直观的思路是将数组排序,然后就可以找出其中最小的k个数了,时间复杂度以快速排序为例,是O(nlogn): 解法2. 借助划分(Partitio ...
- C语言:找出一个大于给定整数m且紧随m的素数,-求出能整除x且不是偶数的数的个数,
//函数fun功能:找出一个大于给定整数m且紧随m的素数,并作为函数值返回. #include <stdlib.h> #include <conio.h> #include & ...
- 设计算法,求AB两个整数集合的交集
[本文链接] http://www.cnblogs.com/hellogiser/p/ab-set-intersection.html [分析] 思路1:排序法 对集合A和集合B进行排序(升序,用快排 ...
随机推荐
- C#之FTP上传下载(二)
这个类几乎包含了对FTP常用的方法,有不对的地方,欢迎批评指正 public class FtpClient { #region 构造函数 /// <summary> /// 创建FTP工 ...
- 初探arch -小白安装arch篇
前段时间突然想试一试arch系统,电脑有点拖不动了,想想可以自己DIY自己需要的东西,就装个arch吧. 于是就马不停蹄的安装. 1.开始:用U盘制作启动盘.这里推荐低量级的制作软件USBwriter ...
- JavaScript数据结构与算法(八) 集合(ECMAScript 6中定义的类似的Set类)
TypeScript方式实现源码 // 特性: // 1. 集合是由一组无序且唯一(即不能重复)的项组成的.这个数据结构使用了与有限集合相同的数学概念,但应用在计算机科学的数据结构中. // 2. 也 ...
- 0312-css样式(选择器、文本text、字体fonts、背景background)
问题: 1.css中table{border:1px:}是定义table的样式,只有表格的外边框,不能实现<table border="1"></table> ...
- angularjs中的几种工具方法
1.比较两个字符串是否相等 2.对象形式转化成json和json转化成字符串形式 3.便利对象遍历数组 4.绑定数据 5.多个app功能模块的实现 <!doctype html><h ...
- 接口自动化测试:python+json+requests+数据驱动
接口测试是单元测试的一个子集,但又不等同于单元测试.从测试的角度来看,接口测试的价值在于其测试投入比单元测试少,而且技术难度也比单元测试小.一般来说,接口测试的粒度要比单元测试更粗,它主要是基于子系统 ...
- Event 发布与订阅(一)
前言 主要讲的是发布与订阅在Event中的一个简单实现用来加深理解. C #中的事件(Event)的理解: 事件具有以下属性:(From Events) 发行者确定何时引发事件:订户确定对事件作出何种 ...
- [BZOJ]2017省队十连测推广赛1 T2.七彩树
题目大意:给你一棵n个点的树,每个点有颜色,m次询问,每次询问一个点x的子树内深度不超过depth[x]+d的节点的颜色数量,强制在线.(n,m<=100000,多组数据,保证n,m总和不超过5 ...
- [SHOI2001]化工厂装箱员
题目描述 118号工厂是世界唯一秘密提炼锎的化工厂,由于提炼锎的难度非常高,技术不是十分完善,所以工厂生产的锎成品可能会有3种不同的纯度,A:100%,B:1%,C:0.01%,为了出售方便,必须 ...
- hdu 5592 BestCoder Round #65(树状数组)
题意: ZYB有一个排列PP,但他只记得PP中每个前缀区间的逆序对数,现在他要求你还原这个排列. (i,j)(i < j)(i,j)(i<j)被称为一对逆序对当且仅当A_i>A_jA ...