数据结构与算法基础(大厂面试题)

1.说一下几种常见的排序算法和时间复杂度?

常用的排序算法的时间复杂度和空间复杂度

排序法

最差时间分析平均时间复杂度稳定度空间复杂度
冒泡排序O(n2)O(n2)稳定O(1)
快速排序O(n2)O(n*log2n)不稳定O(log2n)~O(n)
选择排序O(n2)O(n2)稳定O(1)
二叉树排序O(n2)O(n*log2n)不一顶O(n)

插入排序

O(n2)O(n2)稳定O(1)
堆排序O(n*log2n)O(n*log2n)不稳定O(1)
希尔排序OO不稳定O(1)

2.用java写一个冒泡排序

for(int i=0;i<arr.length();i++){

for(int j=0;j<arr.length()-i-1;j++){

if(arr[j]>arr[j+1]){

int t=arr[j];

arr[j]=arr[j+1];

arr[j+1]=t;

}

}

}

时间复杂度o(n^2)空间o(1)

描述一下链式存储结构?

线性表的链式存储结构:
为什么采用链式存储结构这种数据结构?
–》因为顺序存储结构插入或删除元素时候会涉及大量元素移动,非常影响效率。
因此引入了链式存储结构为了弥补顺序存储结构效率上的问题。
链式存储结构的定义:
1.我们把存储数据元素信息的域称为数据域,把存储直接后继位置的域称为指针域。
2.指针域中存储的信息称为指针或链。这两部分信息组成数据元素称为存储映像,称为结点(Node)。
3.n个结点链接成一个链表,即为线性表(a1, a2, a3, …, an)的链式存储结构。
4.因为此链表的每个结点中只包含一个指针域,所以叫做单链表。
#一个节点Node如下图所示:

如何遍历一颗二叉树?

  • 前序遍历:按照“根左右”,先遍历根节点,再遍历左子树 ,再遍历右子树
  • 中序遍历:按照“左根右“,先遍历左子树,再遍历根节点,最后遍历右子树
  • 后续遍历:按照“左右根”,先遍历左子树,再遍历右子树,最后遍历根节点
    其中前,后,中指的是每次遍历时候的根节点被遍历的顺序

倒排一个linkedlist

第一种方法public Node reverse(Node current) { Node previous = null; Node next = null; while (current != null) { //存储下一节点 next = current.next; current.next = previous; //反转 //更新遍历节点 previous = current; current = next; } return current; }

第二种递归方法public Node reverse(Node current) { if (current == null || current.next == null) return current; Node nextNode = current.next; current.next = null; Node reverseRest = reverse(nextNode); nextNode.next = current; return reverseRest; }

用java写一个递归遍历目录下的子文件?

  public static void showDirectory(File file){
        File[] files = file.listFiles();
        for(File a:files){
            System.out.println(a.getAbsolutePath());
            if(a.isDirectory()){
                showDirectory(a);
            }
        }
    }
 

 

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

饭九钦vlog

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值