对于给定的整数集合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进行排序(升序,用快排 ...
随机推荐
- Java 内部类的意义及应用
众所周知,我们的 C++ 程序语言是多继承制的,而多继承明显的好处就是,相对而言只需要写较少的代码即可完成一个类的定义,因为我们可以通过继承其它类来获取别人的实现. 但是,它也有一个致命性的缺陷,容易 ...
- 在一个没有设置宽高的容器中,为什么设置position:absolute后就可以全屏显示了?
此场景适用于移动端百分比布局,背景全屏显示. 在一个没有设置宽高的容器中设置背景,想要背景全屏显示,设置bcakground-size:100%;后还需设置position:absolut; 原因: ...
- codevs 1054 电梯
1054 电梯 提交地址:http://codevs.cn/problem/1054/ 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 白银 Silver 题目描述 D ...
- Windows 2012服务器安装GPU版TensorFlow完全攻略
一.首先,推荐用Anaconda安装 因为Anaconda本身就已经默认安装了很多常用的Python库,可以省去大量的库安装过程,并且解决兼容性问题. Anaconda本身的安装也非常简单,搜索Ana ...
- [HNOI2012]双十字
题目描述 在C 部落,双十字是非常重要的一个部落标志.所谓双十字,如下面两个例子,由两条水平的和一条竖直的”1“线段组成,要求满足以下几个限制: ![] 我们可以找到 5 个满足条件的双十字,分别如下 ...
- 【网络流问题·我就想建好模】
·为了有助于你读后文,在写题前先列出一些大米饼的代码习惯: 一个提醒:所有的ADD函数无特殊说明均如图:(没有w就直接跳过) 以及: go(i,a,b)=====for(int i=a;i<=b ...
- [BZOJ]1095 Hide捉迷藏(ZJOI2007)
一道神题,两种神做法. Description 捉迷藏 Jiajia和Wind是一对恩爱的夫妻,并且他们有很多孩子.某天,Jiajia.Wind和孩子们决定在家里玩捉迷藏游戏.他们的家很大且构造很奇特 ...
- day5 liaoxuefeng---实战篇
- JS中怎样判断undefined(比较不错的方法)
最近做项目碰到的问题.拿出来跟大家分享一下吧. 用servlet赋值给html页面文本框值后,用alert来弹出这个值.结果显示"undefined".所以我就自然的用这个值和字符 ...
- vscode 搭建go开发环境的13个插件的安装
由于网的问题 大家都不能直接go get 这里从易到难按难度给大家推荐几种方法 最简单的FQ 但是能FQ你还不能装 请问是假的FQ吗? 第一 用git 直接git反而能从那边趴下代码 但是要自己go ...