首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >根据子数组的长度对2d数组进行排序

根据子数组的长度对2d数组进行排序
EN

Stack Overflow用户
提问于 2021-01-19 12:29:17
回答 1查看 284关注 0票数 0

我想完成以下任务:

你会得到一个数组。如果按数组的长度对数组进行排序,您将看到它们的长度值是连续的。但是缺少一个数组!您必须编写一个方法,返回缺失数组的长度。

代码语言:javascript
复制
public static int getLengthOfMissingArray(Object[][] arrayOfArrays) {
    if (arrayOfArrays.length == 0) { //array empty
        return 0;
    }
    for (int i = 0; i < arrayOfArrays.length; i++) {
        //array in the array empty
        if (arrayOfArrays[i].length == 0) {
            return 0;
        }
        if (arrayOfArrays[i].length != arrayOfArrays[i + 1].length - 1) {
            return arrayOfArrays[i].length + 1;
        }
    }
    return 0;
}

这适用于排序数组。所以我只需要一种方法来根据它们的长度来订购。

是否有其他方法根据二维数组的(升序)长度对其进行排序?

例如:[[1,2], [1,5,7],[4]] -> [[4], [1,2], [1,5,7]]

Arrays.sort(arr)不起作用,我得到:

Ljava.lang.Object;不能转换为java.lang.Comparable

EN

回答 1

Stack Overflow用户

发布于 2021-01-19 14:19:04

使用此方法:

代码语言:javascript
复制
public static int[][] sort(int[][] arr) {
    for (int i = 0; i < arr.length; i++) {
        for (int j = i + 1; j < arr.length; j++) {
            if (arr[j].length < arr[i].length) {
                // If the length of the array in j less than the
                // length of the array in i, replace between them
                int[] temp = arr[i];
                arr[i] = arr[j];
                arr[j] = temp;
            }
        }
    }
    return arr;
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65791537

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档