题目】

输入一个正整数数组,将它们连接起来排成一个数,输出能排出的所有数字中最小的一个。例如输入数组{3,32,  321},则输出这两个能排成的最小数字321323。请给出解决问题的算法,并证明该算法。

【思路】

先将整数数组转为字符串数组,然后字符串数组进行排序,最后依次输出字符串数组即可。这里注意的是字符串的比较函数需要重新定义,不是比较a和b,而是比较ab与 ba。如果ab < ba,则a < b;如果ab > ba,则a > b;如果ab = ba,则a = b。比较函数的定义是本解决方案的关键。

结论:如果a < b,那么a排在b前面,否则b排在a前面,这样组成的数字是最小的。

【证明】

如何证明?

证明比较两个数字大小规则是有效的。

证明根据这种规则组合的数字是最小的。

【证明1】

1.证明比较两个数字大小规则是有效的。

一个有效的比较需要三个条件:

(1)自反性,即a等于a;

(2)对称性,即如果a大于b,则b小于a;

(3)传递性,即如果a小于b,b小于c,则a小于c。

现在分别予以证明。

(1)自反性。显然有aa=aa,所以a等于a。

(2)对称性。如果a小于b,则ab<ba,所以ba>ab。因此b大于a。

(3)传递性。 如果a小于b,则ab<ba;如果b小于c,则bc<cb。

举个例子a=1,b=23,c=345。

设a、b、c用十进制表示的时候分别为x位、y位、z位。则ab= a×10y+b,ba=b×10x+a;

则由ab<ba推出a×10y+b< b×10x+a,即a/(10x-1)<b/(10y -1)【结果1】。

同理由bc<cb推出b×10z+c< c×10y+b,即b/(10y-1)<c/(10z -1)【结果2】。

由【结果1】和【结果2】得到a/(10x-1)< c/(10z -1)【结果3】。由【结果3】得到ac<ca,即a小于c。

【证明2】

2.证明根据这种规则组合的数字是最小的。

我们把n个数按照前面的排序规则排好顺序之后,表示为F(n)=A1A2A3…An,则F(n)一定是最小的。

反证法证明:

假设这样排出来的两个数并不是最小的。即至少存在两个x和y(1<=x<y<=n),交换第x个数和地y个数后,使得A1A2…Ay…Ax…An<A1A2…Ax…Ay…An【原结论】。

设F(n)= A1A2…Ax…Ay…An。

因为Ay-1Ay<AyAy-1,则F(n)= A1A2…Ax…Ay…An< A1A2…AxAx+1…AyAy-1…An。同理不断将Ay左移,得到F(n)< A1A2…AyAxAx+1…Ay-2Ay-1…An。

因为AxAx+1<Ax+1Ax,则F(n)< A1A2…AyAx+1AxAx+2…Ay-2Ay-1…An。同理不断将Ax右移,得到F(n)< A1A2…AyAx+1Ax+2…Ay-2Ay-1Ax…An。

即F(n)=A1A2…Ax…Ay…An<A1A2…Ay…Ax…An【新结论】。

【新结论】与【原结论】相矛盾,所以假设不成立,原结论正确,即把n个数按照前面的排序规则排好顺序之后,表示为F(n)=A1A2A3…An,则F(n)一定是最小的。

代码】

 C++ Code 
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
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
 
#include <iostream> // cin cout
#include <string> // string
#include <sstream> // stringstream
#include <algorithm> // sort
using namespace std;

bool compare(const string &str1, const string &str2)
{
    string s1 = str1 + str2;
    string s2 = str2 + str1;
    return s1 < s2;
}

void SortArrayToMinValue(int *data, int length)
{
    )
        return;
    string *strData = new string[length];
    //convert int to string
; i < length; ++i)
    {
        stringstream ss;
        ss << data[i];
        ss >> strData[i];
    }
    // sort string array with user-defined compare function
    sort(strData, strData + length, compare);

// print string array
; i < length; i++)
    {
        cout << strData[i];
    }
    cout << endl;

// free memory
    delete []strData;
    strData = NULL;
}

void test_case()
{
    };
    int length = sizeof(data) / sizeof(int);
    SortArrayToMinValue(data, length);

};
    int length2 = sizeof(data2) / sizeof(int);
    SortArrayToMinValue(data2, length2);
}

int _tmain(int argc, _TCHAR *argv[])
{
    test_case();
    ;
}

【参考】

http://zhedahht.blog.163.com/blog/static/25411174200952174133707/

http://www.cnblogs.com/youxin/p/3294154.html

http://blog.csdn.net/wuzhekai1985/article/details/6704902

41.把数组排成最小的数[Sort array to smallest value]的更多相关文章

  1. 把数组排成最小的数/1038. Recover the Smallest Number

    题目描述 输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个.例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323.   Give ...

  2. 九度OJ 1504 把数组排成最小的数【算法】-- 2009年百度面试题

    题目地址:http://ac.jobdu.com/problem.php?pid=1504 题目描述: 输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个.例如 ...

  3. 《剑指offer》— JavaScript(32)把数组排成最小的数

    把数组排成最小的数 题目描述 输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个.例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为3213 ...

  4. 剑指Offer - 九度1504 - 把数组排成最小的数

    剑指Offer - 九度1504 - 把数组排成最小的数2014-02-06 00:19 题目描述: 输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个.例如输 ...

  5. 剑指Offer:把数组排成最小的数【45】

    剑指Offer:把数组排成最小的数[45] 题目描述 输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个.例如,输入数组是{3.32.321},则打印出来的这3 ...

  6. leetcode 179. Largest Number 、剑指offer33 把数组排成最小的数

    这两个题几乎是一样的,只是leetcode的题是排成最大的数,剑指的题是排成最小的 179. Largest Number a.需要将数组的数转换成字符串,然后再根据大小排序,这里使用to_strin ...

  7. php实现把数组排成最小的数(核心是排序)(看别人的代码其实也没那么难)(把php代码也看一下)(implode("",$numbers);)(usort)

    php实现把数组排成最小的数(核心是排序)(看别人的代码其实也没那么难)(把php代码也看一下)(implode("",$numbers);)(usort) 一.总结 核心是排序 ...

  8. 力扣 - 剑指 Offer 45. 把数组排成最小的数

    题目 剑指 Offer 45. 把数组排成最小的数 思路1 将整数数组转化成字符串数组 然后使用Arrays工具类的sort方法帮助我们排序 代码 class Solution { public St ...

  9. 把数组排成最小的数 牛客网 剑指Offer

    把数组排成最小的数 牛客网 剑指Offer 题目描述 输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个.例如输入数组{3,32,321},则打印出这三个数字能 ...

随机推荐

  1. 用SQL打印乘法口诀表

    --用SQL打印出乘法口诀表 declare @i int ,@j int --@i是乘法口诀的行数 --一共九行 begin --每次都是从1*开始,j每循环一次递增 )--print每次输出都会换 ...

  2. Java-如何挖取某个网站中的ajax请求信息

    通常情况,通过网络爬虫挖取到的基本为网页静态内容,而动态ajax取数的内容是我个人暂时不知如何一次性把网站中的ajax获取 这里介绍的是某个网站中的某一个ajax多某个table刷新,期数据,并提供其 ...

  3. POJ3579 Median

    Description Given N numbers, X1, X2, ... , XN, let us calculate the difference of every pair of numb ...

  4. POJ1523 SPF

    Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 8254   Accepted: 3772 Description Consi ...

  5. javascript-如何判断一个对象为数组

    Q:如何判断一个对象是否为数组? A1:判断对象的constructor是否指向Array, 接着判断对应的特殊属性,如length,splice之类.这个很容易冒充. A2:使用instanceof ...

  6. Mac OS X 10.9 Mavericks安装后,Xcode调试时模拟器黑屏的处理方法

    请耐心的等下去吧,少年! 装了Mac OS X 10.9 Mavericks的同学,如果碰到Xcode调试App时,模拟器黑屏(重置也无效),请耐心的等下去吧,大约10来分钟左右黑屏就会消失,App启 ...

  7. 深入理解 Javascript 面向对象编程

    一:理解构造函数原型(prototype)机制 prototype是javascript实现与管理继承的一种机制,也是面向对象的设计思想.构造函数的原型存储着引用对象的一个指针,该指针指向与一个原型对 ...

  8. NoClassDefFoundError: org/slf4j/LoggerFactory解决

    缺少slf4j-api-1.5.2,slf4j-log4j12-1.5.2,log4j-1.2.8这几个包,导入即可

  9. [bug]The file ‘/xxx/xxx.aspx’ has not been pre-compiled, and cannot be requested

    今天莫名奇妙的出现了这个问题,查找很多资料最后解决了. 发现编译的时候,少了一个dll,导致预编译失败. 参考资料 https://blogs.msdn.microsoft.com/asiatech/ ...

  10. fp = fopen(s, "at") 中at 是啥意思,a 是append 追加的意思

    打开一个s的stream, a表示append,就是说写入处理的时候是接着原来文件已有内容写入,不是从头写入覆盖掉, t表示打开文件的类型是文本文件, "+号表示对文件既可以读也可以写.&q ...