freeCodeCamp/curriculum/challenges/japanese/10-coding-interview-prep/rosetta-code/largest-int-from-concatenat...

1.8 KiB

id title challengeType forumTopicId dashedName
5a23c84252665b21eecc7edb 連結整数の最大整数 5 302298 largest-int-from-concatenated-ints

--description--

指定された正の整数一式に対して、この数字の連結が最大の整数を形成するように整数を並び替え、この最大整数を返すような関数を記述してください。

--hints--

maxCombine は関数とします。

assert(typeof maxCombine == 'function');

maxCombine([1, 3, 3, 4, 55]) は数値を返す必要があります。

assert(typeof maxCombine([1, 3, 3, 4, 55]) == 'number');

maxCombine([1, 3, 3, 4, 55])554331 を返す必要があります。

assert.equal(maxCombine([1, 3, 3, 4, 55]), 554331);

maxCombine([71, 45, 23, 4, 5])71545423 を返す必要があります。

assert.equal(maxCombine([71, 45, 23, 4, 5]), 71545423);

maxCombine([14, 43, 53, 114, 55])55534314114 を返す必要があります。

assert.equal(maxCombine([14, 43, 53, 114, 55]), 55534314114);

maxCombine([1, 34, 3, 98, 9, 76, 45, 4])998764543431 を返す必要があります。

assert.equal(maxCombine([1, 34, 3, 98, 9, 76, 45, 4]), 998764543431);

maxCombine([54, 546, 548, 60])6054854654 を返す必要があります。

assert.equal(maxCombine([54, 546, 548, 60]), 6054854654);

--seed--

--seed-contents--

function maxCombine(xs) {

}

--solutions--

function maxCombine(xs) {
  return parseInt(
    xs
      .sort(function(x, y) {
        var a = x.toString(),
          b = y.toString(),
          ab = parseInt(a + b),
          ba = parseInt(b + a);

        return ab > ba ? -1 : ab < ba ? 1 : 0;
      })
      .join(''),
    10
  );
}