Java数据结构:OJ练习题(解析)

计算元素移动次数

  1. 在长度为 n 的顺序表下标为 i 的位置前插入一个元素(1 ≤ i ≤ n+1),元素的移动次数为( )
    A.n - i + 1
    B.n - i
    C.i
    D.i - 1
    答案:B
    在这里插入图片描述
    在这里插入图片描述
    即:把[i, n - 1]区间的元素全部向后移动一次,故移动的次数为n - 1 - i + 1。

ArrayList类

2.对于类java.util.ArrayList,哪个语句是正确的?
A.ArrayList中的元素是有序的。

B.ArrayList中的元素保证是可变的。

C.ArrayList中的元素保证是唯一的。

D.使用唯一密钥访问ArrayList中的元素。

A错误:ArrayList中的元素不一定有序,ArrayList没有要求里面的元素必须有序,可能有序也可能不有序
B正确:ArrayList中的元素可以通过下标修改
C错误:ArrayList中的元素每一要求必须要唯一,可以唯一也可以重复
D错误:ArrayList中的元素是通过下标访问的,而不是通过key
故正确应该选择B

杨辉三角

public class Solution {
    public List<List<Integer>> generate(int numRows) {
        List<List<Integer>>ret=new ArrayList<>();

        List<Integer>row=new ArrayList<>();
        row.add(1);

        ret.add(row);
        for (int i=1;i<numRows;i++){
        List<Integer>preRow=ret.get(i-1);//前一行
        List<Integer>curRow=new ArrayList<>();
        curRow.add(1); //顺序表的第一个1
        //中间curRow list的赋值

        //j活动的范围
        for(int j=1;j<i;j++){
            int x=preRow.get(j)+preRow.get(j-1);
            curRow.add(x);
        }
        curRow.add(1);//顺序表的最后一个1
        ret.add(curRow);
        }
        return ret;
    }
}

在这里插入图片描述
解题思路:
仔细观察发现杨辉三角类似于一个二维数组,第0列和对角线上的元素全部都是1
其余位置都是上一行正对元素 与 上一行正对元素的前一个元素之和
在这里插入图片描述
![在这里插入图片描述](https://img-blog.csdnimg.cn/c573e3f7edee419093f8692b5cfaaa97.png

先确定第一个数组和最后一个数组的元素都为1,中间的数组用循环嵌套赋值。

合并两个有序数组

import java.util.Arrays;

public class Solution {
    public void merge(int[] nums1, int m, int[] nums2, int n) {
        for(int i=-0;i!=n;++i){
        //将数组nums2的元素写入nums1
            nums1[m+i]=nums2[i];
        }
        Arrays.sort(nums1);
    }
}

先合并,然后用java自带sort方法进行删重。

class Solution {
    public void merge(int[] nums1, int m, int[] nums2, int n) {
        // end1、end2:分别标记nums1 和 nums2最后一个有效元素位置
        // end标记nums1的末尾,因为nums1和nums2中的元素从后往前往nums1中存放
        // ,否则会存在数据覆盖
        int end1 = m-1;
        int end2 = n-1;
        int end = nums1.length-1;

        // 从后往前遍历,将num1或者nums2中较大的元素往num1中end位置搬移
        // 直到将num1或者num2中有效元素全部搬移完
        while(end1 >= 0 && end2 >= 0){
            if(nums1[end1] > nums2[end2]){
                nums1[end--] = nums1[end1--];
            }else{
                nums1[end--] = nums2[end2--];
            }
        }

        // 如果nums2中的数据没有搬移完,搬移剩余nums中的元素
        while(end2 >= 0){
            nums1[end--] = nums2[end2--];
        }

        // num1中可能有数据没有搬移完,不用管,因为这些元素已经在nums1中了
    }
}

解题思路:
1. 从后往前遍历数组,将nums1和nums2中的元素逐个比较
将较大的元素往nums1末尾进行搬移
2. 第一步结束后,nums2中可能会有数据没有搬移完,将nums2中剩余的元素逐个搬移到nums1
在这里插入图片描述
利用三个逆向指针进行归并。

删除排序数组中的重复项

public int removeDuplicates(int[] nums) {
        int n = nums.length;
        if (n == 0) {
            return 0;
        }
        int fast = 1, slow = 1;
        while (fast < n) {
            if (nums[fast] != nums[fast - 1]) {
                nums[slow] = nums[fast];
                ++slow;
            }

            ++fast;
        }
        return slow;
    }

定义两个指针 fast 和 slow 分别为快指针和慢指针,快指针表示遍历数组到达的下标位置,慢指针表示下一个不同元素要填入的下标位置,初始时两个指针都指向下标。
在这里插入图片描述


class Solution {
    public int removeDuplicates(int[] nums) {
        int count = 1;   // 标记从前往后遍历时,遇到的不同元素的个数
        for(int i = 1; i < nums.length; ++i){
            // 注意:count是从前往后遍历时遇到的不同元素的个数
            //       count-1就是i位置之前最后一个不同元素的位置
            // 因此需要将num[i]搬移到nums[count]处
            if(nums[count-1] != nums[i]){
                nums[count++] = nums[i];
            }
        }

        return count;
    }
}

解题思路:
1. 设置一个计数,记录从前往后遍历时遇到的不同元素的个数
由于不同的元素需要往前搬移,那count-1就是前面不同元素
搬移之后,最后一个元素的位置,下一次在遇到不同元素就应该
搬移到count位置
2. 遍历数组,如果nums[i]与nums[count-1]不等,就将nums[i]搬移
到nums[count]位置,不同元素多了一个,给count++
3. 循环结束后,返回count 。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1.1 单项选择题 1. 数据结构是一门研究非数值计算的程序设计问题中,数据元素的① 、数据信息在计算机中的② 以及一组相关的运算等的课程。 ① A.操作对象   B.计算方法  C.逻辑结构  D.数据映象 ② A.存储结构 B.关系 C.运算 D.算法 2. 数据结构DS(Data Struct)可以被形式地定义为DS=(D,R),其中D是① 的有限集合,R是D上的② 有限集合。 ① A.算法 B.数据元素 C.数据操作 D.数据对象 ② A.操作 B.映象 C.存储 D.关系 3. 在数据结构中,从逻辑上可以把数据结构分成 。 A.动态结构和静态结构 B.紧凑结构和非紧凑结构 C.线性结构和非线性结构 D.内部结构和外部结构 4. 算法分析的目的是① ,算法分析的两个主要方面是② 。 ① A. 找出数据结构的合理性 B. 研究算法中的输入和输出的关系 C. 分析算法的效率以求改进 D. 分析算法的易懂性和文档性 ② A. 空间复杂性和时间复杂性 B. 正确性和简明性 C. 可读性和文档性 D. 数据复杂性和程序复杂性 5. 计算机算法指的是① ,它必具备输入、输出和② 等五个特性。 ① A. 计算方法 B. 排序方法 C. 解决问题的有限运算序列 D. 调度方法 ② A. 可行性、可移植性和可扩充性 B. 可行性、确定性和有穷性 C. 确定性、有穷性和稳定性 D. 易读性、稳定性和安全性 1.2 填空题(将正确的答案填在相应的空中) 1. 数据逻辑结构包括 、 、 和 四种类型,树形结构和图形结构合称为 。 2. 在线性结构中,第一个结点 前驱结点,其余每个结点有且只有 个前驱结点;最后一个结点 后续结点,其余每个结点有且只有 个后续结点。 3. 在树形结构中,树根结点没有 结点,其余每个结点有且只有 个直接前驱结点,叶子结点没有 结点,其余每个结点的直接后续结点可以 。 4. 在图形结构中,每个结点的前驱结点数和后续结点数可以 。 5. 线性结构中元素之间存在 关系,树形结构中元素之间存在 关系,图形结构中元素之间存在 关系。 6. 算法的五个重要特性是__ __ , __ __ , ___ _ , __ __ , _ ___。 7. 分析下面算法(程序段),给出最大语句频度 ,该算法的时间复杂度是__ __。 for (i=0;i<n;i++) for (j=0;j<n; j++) A[i][j]=0; 8. 分析下面算法(程序段),给出最大语句频度 ,该算法的时间复杂度是__ __。 for (i=0;i<n;i++) for (j=0; j<i; j++) A[i][j]=0; 9. 分析下面算法(程序段),给出最大语句频度 ,该算法的时间复杂度是__ __。 s=0; for (i=0;i<n;i++) for (j=0;j<n;j++) for (k=0;k<n;k++) s=s+B[i][j][k]; sum=s; 10. 分析下面算法(程序段)给出最大语句频度 ,该算法的时间复杂度是__ __。 int i=0,s=0; while (s<n) { i++; s+=i; //s=s+i } 11. 分析下面算法(程序段)给出最大语句频度 ,该算法的时间复杂度是__ __。 i=1; while (i<=n) i=i*2;

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值