zoukankan      html  css  js  c++  java
  • 把数组排成最小的数

    题目描述

    输入一个正整数数组,把数组里所有数字拼接起来排成一个数,打印能拼接出的所有数字中最小的一个。例如输入数组{3,32,321},则打印出这三个数字能排成的最小数字为321323。
    代码:
        static bool cmp(int a,int b)
        {
            string A = to_string(a) + to_string(b);
            string B = to_string(b) + to_string(a);
            return A < B;
        }
        string PrintMinNumber(vector<int> numbers) {
            sort(numbers.begin(),numbers.end(),cmp);
            string str = "";
            for(int i = 0; i < numbers.size();i++)
            {
                str += to_string(numbers[i]);
            }
            return str;
        }

    对于sort函数:sort函数对于不同的数据选择不同的排序方法。大概包括快速排序,插入排序和堆排序。比如给一个数据量较大的数组排序,开始采用快速排序,分段递归,分段之后每一段的数据量达到一个较小值后它就不继续往下递归,而是选择插入排序,如果递归的太深,他会选择推排序。

  • 相关阅读:
    hadoop day 5
    SSM前言——相关设计模式
    多线程技术点二
    其他对象
    集合拾遗
    入职技术准备
    File类相关操作
    IO流技术
    多线程技术点
    第二章
  • 原文地址:https://www.cnblogs.com/Lune-Qiu/p/9147251.html
Copyright © 2011-2022 走看看