CC ANUMLA(STL的运用)
题目连接:http://www.codechef.com/problems/ANUMLA
题意:给一个序列所有子集和(2^n个子集),复原这个序列。。。
如:0 1 1 2 2 3 3 4 原序列为1 1 2
分析:每次找出最小的那个元素,再删除掉可能由该元素相加得到的元素,如上面那个例子,将所有可能相加得到其他元素存在一个数组add中,0是空集,先去掉,剩下第一个元素1必定是原序列最小元素,取出答案数组ans中,一步步下去。
1.取出1放进ans数组中,ans数组:1 相加辅助数组add:1,删除1后原序列:1 2 2 3 3 4
2.取出最小元素1放进ans数组,ans数组1 1 相加辅助数组add:1 1 2(1+1,1),删除1,2后序列:2 3 3 4
3.取出最小元素2放进ans数组,ans数组1 1 2 相加辅助数组add:1 1 2 2 3 3 4(1+2,1+2,2+2,2),删除2,3,3,4后原序列已空。
同样序列0 2 5 7 10 12 15 17去掉0,原序列为 2 5 7 10 12 15 17
1.取出1放进ans数组中,ans数组:2 相加辅助数组add:2,删除2后原序列: 5 7 10 12 15 17
2.取出最小元素5放进ans数组,ans数组2 5 相加辅助数组add:2,5,7(2+5,5),删除5,7后序列:10 12 15 17
3.取出最小元素10放进ans数组,ans数组2 5 10 相加辅助数组add:2 5 7 10 12 15 17(10+2,10+5,10+7,10),删除2,3,3,4后原序列已空。
这题用STL中的multiset处理起来太方便了。
#include<bits/stdc++.h>
using namespace std;
multiset<int>Set;
vector<int>ans,add;
int main()
{
int T,n,x;
scanf("%d",&T);
while(T--)
{
scanf("%d",&n);
Set.clear();ans.clear();add.clear();
for(int i=;i<(<<n);i++)
{
scanf("%d",&x);
Set.insert(x);
}
Set.erase();
x=n;
while(x--)
{
int mn=*(Set.begin());//取出最小元素放进ans数组
ans.push_back(mn);
for(int i=,sz=add.size();i<sz;i++)
{
int ad=add[i]+mn;add.push_back(ad);
Set.erase(Set.find(ad));//删除由各个元素相加得到的子集
}
add.push_back(mn);
Set.erase(Set.find(mn));
}
for(int i=,sz=ans.size();i<sz;i++)printf("%d%c",ans[i],(i==n-)?'\n':' ');
}
}
CC ANUMLA(STL的运用)的更多相关文章
- STL 堆
		洛谷P3378 [模板]堆 #include <iostream> #include <cstdio> #include <algorithm> #include ... 
- c++ STL 学习记录 草稿。
		非常丑陋的尝试实现stl.慢慢修改吧. 1)简单实现 vector和list. 2)思索如何开始编写算法. 1,所有容器继承一个抽象容器.那么算法就可以使用抽象基类的next方法来遍历元素. 容器间耦 ... 
- STL区间成员函数及区间算法总结
		STL区间成员函数及区间算法总结 在这里总结下可替代循环的区间成员函数和区间算法: 相比单元素遍历操作,使用区间成员函数的优势在于: 1)更少的函数调用 2)更少的元素移动 3)更少的内存分配 在区间 ... 
- 高效的使用STL
		高效的使用STL 仅仅是个选择的问题,都是STL,可能写出来的效率相差几倍: 熟悉以下条款,高效的使用STL: 当对象很大时,建立指针的容器而不是对象的容器 1)STL基于拷贝的方式的来工作,任何需要 ... 
- 常用的STL查找算法
		常用的STL查找算法 <effective STL>中有句忠告,尽量用算法替代手写循环:查找少不了循环遍历,在这里总结下常用的STL查找算法: 查找有三种,即点线面: 点就是查找目标为单个 ... 
- [转]  深入剖析 linux GCC 4.4 的 STL string
		本文通过研究STL源码来剖析C++中标准模板块库std::string运行机理,重点研究了其中的引用计数和Copy-On-Write技术. 平台:x86_64-redhat-linux gcc ver ... 
- C++STL之string (转)
		在学习c++STL中的string,在这里做个笔记,以供自己以后翻阅和初学者参考. 1:string对象的定义和初始化以及读写 string s1; 默认构造函数,s1为空串 string ... 
- C++STL之String
		本文直接转载,非原创!仅记录供自己学习之用. 出处:http://blog.csdn.net/y990041769/article/details/8763366 在学习c++STL中的string, ... 
- STL——配接器、常用算法使用
		学习STL,必然会用到它里面的适配器和一些常用的算法.它们都是STL中的重要组成部分. 适配器 在STL里可以用一些容器适配得到适配器.例如其中的stack和queue就是由双端队列deque容器适配 ... 
随机推荐
- XML 关键字
			SGML--Standard Generalized Marked Language 标准通用标记语言GML--Generalized Marked Language 通用标记语言XML--Extes ... 
- wift - 使用UIScreen类获取屏幕大小尺寸
			UISreen类代表了屏幕,开发中一般用来获取屏幕相关的属性,例如获取屏幕的大小. 1 2 3 4 5 6 7 //获取屏幕大小 var screenBounds:CGRect = UIScreen. ... 
- 高性能C++网络库libtnet实现:Connection
			Connection libtnet只支持IPv4 TCP Connection,之所以这么做都是为了使得实现尽可能的简单.我们主要在Connection类中封装了对tcp连接的操作. Connect ... 
- mysql 父子结构排序
			项目中常常会遇到父子结构显示的问题,不同的数据库有不同的写的方式,比方SqlServer中用with union 实现.而Mysql则没有这么方便的语句. 例如以下category表.食品有pizaa ... 
- php中include文件变量作用域的研究
			原文:php中include文件变量作用域的研究 在php中我们有时候需要include一个文件.比如我前段时间在写一个框架的时候,打算用原生的php作为模板,然后写一个display方法引入模板文件 ... 
- 在实体类中将数据库中数据类型为CLOB的数据转化成String类型
			@Lob @Basic(fetch = FetchType.EAGER) @Column(name = "JYAQ", columnDefinition = &qu ... 
- Linux网络基础配置
			这是看itercast视频的笔记 Linux网络基础配置 以太网连接 在Linux中,以太网接口被命令为:eth0, eth1等, 0,1代表网卡编号 通过lspci命令可以查看网上硬件信息(如果是u ... 
- Swift - 复杂数据类型说明(数组,字典,结构体,枚举)
			1,数组 - Array 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 var types ... 
- [C#基础] 数据类型
			预定义类型 C#提供了16种预定义类型,其中包括13种简单类型和3种非简单类型. 预定义的简单类型包括以下3种: 11种数值类型 不同长度有符号和无符号的整数类型(8种) 浮点数类型float和dou ... 
- android studio下的NDK开发详解(一)
			源地址:http://www.voidcn.com/blog/chengkaizone/article/p-5761016.html 好记性不如烂笔头,开始坚持写博客,学一点记一点,只为了生活更好. ... 
