C++数组排成最大的数(数组,算法,排列)

//把数组排成最大的数(数组、算法)。
//题目:输入一个正整数数组,将它们连接起来排成一个数,输出能排出的所有数字中最大的一个。
//例如输入数组{32,  321},则输出这两个能排成的最大数字32321.。
//或者输入数组{10,9,33,1000}输出这四个能排列的最大数字933101000.
#include <iostream>
#define MAXSIZE 100
using namespace std;

template<typename T>
class Grial
{
	public:
		int Length(int x,int& n)
		{
			n++;
		  (x/10)&& (Length(x/=10,n));
			return n;
		}//求数字的位数。
		bool Complate(int x,int y)//比较x,y的大小,是组合排列大小,看xy比yx的大小,从而好形成大堆。
		{
			int _I = 0;
			int i = 0;
			int j = 0;
			int sum_1=x;
			int sum_2=y;
					Length(x,i);
			    Length(y,j);
			for(;_I<j;_I++)
			{
				sum_1*=10;
			}
			for(_I=0;_I<i;_I++)
			{
				sum_2*=10;
			}
			if((sum_1+y)>(sum_2+x))return true;
			else
				return false;
		}
		Grial(T a[],int n)
		{
			data = new  T[n];
			size = n;
			for(int i=0;i<n;i++)
			{
				data[i] = a[i];
			}
			int m = size/2;
			while(m<size)
			{
				MaxSort(m);
				m++;
			}
		}
		void MaxSort(int n)//大堆排列
		{
				int temp;
				int i=n;
				int j=(i-1)/2;
				while(i>0)
				{
						if(!Complate(data[j],data[i]))
							{
							temp = data[i];
							data[i]=data[j];
							data[j]=temp;
							}
							i = j;
							j = (i-1)/2;
				}
		}
		int GetTop()//得到大堆第一个元素,并且将最后面一个元算放在下标为0的位置,再进行大堆排序.
		{
			if(size==0)return -1;
			int temp = data[0];
			data[0] = data[size-1];
			size--;
			int m = size/2;
			while(m<size)
			{
				MaxSort(m);
				m++;
			}
			return temp;
		}
		void GetSum()
		{
			int i = GetTop();
			if(i!=-1)
			{
				cout<<i;
			  GetSum();
			}
		}//输出数据.
	private:
		T *data;
		int size;
};
int main()
{
	int a[]={1,9,100001,1001111,98};
		Grial<int> G(a,5);
	//结果是99811001111100001满足最大排列组合.
	G.GetSum();
  cout<<endl;
	return 0;
}

时间: 2024-10-11 11:03:17

C++数组排成最大的数(数组,算法,排列)的相关文章

编程算法 - 把数组排成最小的数 代码(C)

把数组排成最小的数 代码(C) 本文地址: http://blog.csdn.net/caroline_wendy 题目: 输入一个正整数数组, 把数组里所有数字拼接起来排成一个数, 打印能拼接出的所有数字中最小的一个. 大数转换为字符串, 重载快速排序的比较方法, 进行排序, 最后拼接. 代码: /* * main.cpp * * Created on: 2014.6.12 * Author: Spike */ /*eclipse cdt, gcc 4.8.1*/ #include <stdi

微软算法100题68 用数组排成最小的数

68.把数组排成最小的数.题目:输入一个正整数数组,将它们连接起来排成一个数,输出能排出的所有数字中最小的一个.例如输入数组{32, 321},则输出这两个能排成的最小数字32132.请给出解决问题的算法,并证明该算法 1 package com.rui.microsoft; 2 3 import java.util.Arrays; 4 import java.util.Comparator; 5 6 public class Test68_Minimum { 7 8 public static

剑指OFFER之把数组排成最小的数(九度OJ1504)

题目描述: 输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个.例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323. 输入: 输入可能包含多个测试样例.对于每个测试案例,输入的第一行为一个整数m (1<=m <=100)代表输入的正整数的个数.输入的第二行包括m个正整数,其中每个正整数不超过10000000. 输出: 对应每个测试案例,输出m个数字能排成的最小数字. 样例输入: 3 23 13 6 2 23456 56 样

【编程题目】把数组排成最小的数

68.把数组排成最小的数(数组.算法).题目:输入一个正整数数组,将它们连接起来排成一个数,输出能排出的所有数字中最小的一个.例如输入数组{32, 321},则输出这两个能排成的最小数字 32132.请给出解决问题的算法,并证明该算法. 思路:首先,肯定要考虑溢出问题.开始想用字符串,后来改为了用list.思路是先把第一个数字放入list,然后依次把后面的数字插入到合适的位置. 关键问题就是如何判断两个数字哪一个在前面. ①对于 353 .412这样的情况,肯定是第一个数字小的在前面 ②遇到数字

41.把数组排成最小的数

http://zhedahht.blog.163.com/blog/static/25411174200952174133707/ http://www.cnblogs.com/youxin/p/3294154.html http://blog.csdn.net/wuzhekai1985/article/details/6704902 问题描述:输入一个正整数数组,将它们连接起来排成一个数,输出能排出的所有数字中最小的一个.例如输入数组{3,32,  321},则输出这两个能排成的最小数字321

剑指Offer面试题33(java版):把数组排成最小的数

题目:输入一个正整数数组,把数组里面所有的数字拼接排成一个数,打印能拼接出的所有数字中的一个.例如输入数组{3,32,321},则打印出这3个数字能排成的最小数字321323. 这个题目最直接的做法应该是先求出这个数组中的所有数字的全排列,然后把每个排列拼接起来,最后求出排列起来的数字的最小值.求数组的排列和面试题28非常相似.根据排列组合的只是,n个数字总共有n!排列,我们再来看一下更快的算法. 这道题其实希望我们能够找到一个排序规则,数组根据这个规则排序之后能排成一个最小的数字.要确定排序的

剑指Offer对答如流系列 - 把数组排成最小的数

面试题45:把数组排成最小的数 题目描述 输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个.例如输入数组{3, 32, 321},则打印出这3个数字能排成的最小数字321323. 问题分析 之前我们做过字符全排列的习题 剑指Offer对答如流系列 - 字符串的排列,但是将算法思想应用到这一题的话,效果不好,求出所有的组合,再计算出组合的最小值,这效率该多低啊. 我们还要进一步探究,看看有没有不错的规律,供我们使用. 因为数字拼接后的长度一样,拼接后的结果

【面试题033】把数组排成最小的数

[面试题033]把数组排成最小的数 题目: 输入一个正整数数组,把数组里所有数字拼接起来排成一个数, 打印能拼接出的所有数字中最小的一个. 例如输入数组{3, 32, 321},则打印出这3个数字能排成的最小数字321323. 思路一: 最直观的想法是求出所有数字的全排列,然后取最小值即可, 根据排列组合的知识,n个数字总共有n!个排列. 思路二: 找到一个排序规则,数组根据这个规则排序之后能排成一个最小的数字. 给出一个规则,判断给出的两个 数字m和n,判断这两个数那个应该排在前面,而不是仅仅

把数组排成最小的数-剑指Offer

把数组排成最小的数 题目描述 输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个.例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323. 思路 把两个int类型的数拼起来可能会比较大,溢出,我们可采用字符串来表示,处理大数问题 将数字转化为字符串,然后比较字符串的大小,此处的大小指的是:若str1+str2 > str2+str1,则str1 > str2, 我们需要重新定义一个compare函数 其实最后的连接起来的大小和