码迷,mamicode.com
首页 > 编程语言 > 详细

剑指offer 面试题33—把数组排成最小的数

时间:2015-05-06 11:07:35      阅读:126      评论:0      收藏:0      [点我收藏+]

标签:剑指offer   剑指offer 面试题33   把数组排成最小的数   

题目:

输入一个正整数数组,把数组里面的所有数字连接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{3, 32,  321},则打印这三个数字能排成的最小数字321323


基本思想:O(nlogn)

两个数字m和n能拼接数字mn和nm。如果mn<nm,那么我们应该打印出mn,也就是m应该排在n的前面,我们定义此时m小于n;反之,如果nm<mn,我们定义n小于m。如果mn=nm,m等于n。

如对321和32,排序为32132<32321,所以321<32(这个小于号并非是比较两个数的实际大小)。

#include <iostream>
using namespace std;

const int g_MaxNumberLength=10;
char* g_StrCombine1=new char[g_MaxNumberLength*2+1];
char* g_StrCombine2=new char[g_MaxNumberLength*2+1];

int compare(const void* strNumber1, const void* strNumber2)  //对两个数进行比较,ab和ba的大小
{
	strcpy(g_StrCombine1, *(const char**)strNumber1);
	strcat(g_StrCombine1, *(const char**)strNumber2);

	strcpy(g_StrCombine2, *(const char**)strNumber2);
	strcat(g_StrCombine2, *(const char**)strNumber1);

	return strcmp(g_StrCombine1, g_StrCombine2);
}

void PrintMinNumber(int *numbers, int length)
{
	if(numbers == NULL || length <= 0)
		return;
	int i;

	char** strNumbers = (char**)(new int[length]);
	for(i = 0; i < length; i++)
	{
		strNumbers[i] = new char[g_MaxNumberLength+1];
		sprintf(strNumbers[i], "%d", numbers[i]);  //数字转为字符串
	}

	qsort(strNumbers, length, sizeof(char*), compare);

	for(i = 0; i < length; i++)
		cout << strNumbers[i];
	cout << endl;

	for(i = 0; i < length; i++)
		delete[] strNumbers[i];

	delete[] strNumbers;

}

int main()
{
	int num;
	cout << "请输入数组的个数:";
	cin >> num;
	
	int *numbers = new int[num];
	cout << "请进行输入:";
	for(int i = 0; i < num; i++)
		cin >> numbers[i];

	PrintMinNumber(numbers, num);

	return 0;
}

技术分享

剑指offer 面试题33—把数组排成最小的数

标签:剑指offer   剑指offer 面试题33   把数组排成最小的数   

原文地址:http://blog.csdn.net/wtyvhreal/article/details/45531175

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!