数据结构:阶段测试(查漏补缺)

这篇具有很好参考价值的文章主要介绍了数据结构:阶段测试(查漏补缺)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

数据结构:阶段测试(查漏补缺),数据结构练习,1024程序员节,c语言,开发语言,数据结构,c++,算法,单元测试

目录

选择题:

题一:

题二:

题三:

题四:

编程题:

题一:左叶子之和

思路一:

题二:约瑟夫问题(用单链表实现)

思路一:

本人实力有限可能对一些地方解释和理解的不够清晰,可以自己尝试读代码,或者评论区指出错误,望海涵!

感谢大佬们的一键三连! 感谢大佬们的一键三连! 感谢大佬们的一键三连!


选择题:

题一:

1.将长度为n的单链表连接在长度为m的单链表之后,其算法的时间复杂度为() 

A. O(m)

B. O(1)

C. O(n)

D. O(m+n)

答案解析:

        长度为n的单链表链接长度为m的单链表只需要长度为m的单链表的头节点的地址,所以时间复杂度还是O(n)。

题二:

2.以下属于链表的优点的是( )

A. 用数组可方便实现

B. 插入操作效率高

C. 不用为节点间的逻辑关系而增加额外的存储开销

D. 可以按元素号随机访问

答案解析:

        链表插入不需要挪动数据,所以插入效率高。

题三:

3.对于序列{ 12,13,11,18,60,15,7,19,25,100 },用筛选法建堆,应该从值为()的数据开始建初始堆

A. 100

B. 12

C. 60

D. 15

答案解析:

        一共有10个数据,下标为0--9,建堆需要从最后一层的父节点开始,所以,最后一个元素的父节点为:(9 - 1) / 2 = 4,以4为下标的元素为60.

题四:

4.将整数数组( 7-6-3-5-4-1-2 )按照堆排序的方式进行升序排列,请问在第一轮排序结束之后,数组的顺序是()

A. 1-2-3-4-5-6-7

B. 2-6-3-5-4-1-7

C. 6-5-3-2-4-1-7

D. 5-4-3-2-1-6-7

答案解析:

        堆排序实现参考:数据结构:一篇拿捏十大排序(超详细版)-CSDN博客可知C正确。

编程题:

题一:左叶子之和

左叶子之和_牛客题霸_牛客网 (nowcoder.com)

数据结构:阶段测试(查漏补缺),数据结构练习,1024程序员节,c语言,开发语言,数据结构,c++,算法,单元测试

思路一:

        第一步:首先:判断是否为空树;

        第二步:在确保当前节点左子树存在的情况下,判断当前节点的左子树的左子树和右子树是否为空,为空则记录当前节点的左子树的值;

        第三步:将当前节点继续遍历左子树和右子树进行递归遍历整棵树,将所有符合第二步的节点值记录,最后合并,返回。

int sumOfLeftLeaves(struct TreeNode* root ) 
{
    if(root == NULL)
    {
        return 0;
    }
    int sum = 0;
    if(root->left && root->left->left == NULL && root->left->right == NULL)
    {
        sum +=  root->left->val;
    }

    sum += sumOfLeftLeaves(root->left) + sumOfLeftLeaves(root->right);

    return sum;
}

题二:约瑟夫问题(用单链表实现)

约瑟夫环__牛客网 (nowcoder.com)

数据结构:阶段测试(查漏补缺),数据结构练习,1024程序员节,c语言,开发语言,数据结构,c++,算法,单元测试

思路一:

        构建值为1~n的n个节点的循环链表2.实现约瑟夫环,借助cur从链表起始位置开始报数,因为约瑟夫环最终只剩余一个节点,即cur->next != cur时,说明链表中不止一个节点,则循环进行以下操作报数,即遍历链表,循环m-1次,循环停止时,cur即为报m的节点删除该节点,遍历时保存cur的前一个prev,删除cur,然后将cur放在prev的下一个;

        最后剩余的一个节点中的值域就是最后留下来的人。注意:在返回之后一定要把最后一个节点释放掉,否则会有内存泄漏。

#define _CRT_SECURE_NO_WARNINGS 1

//约瑟夫问题

#include <stdio.h>
typedef struct List
{
    struct List* front;
    int val;
    struct List* next;
}L;

L* Init(int x)
{
    L* tmp = (L*)malloc(sizeof(L));
    tmp->val = x;
    tmp->next = NULL;
    tmp->front = NULL;

    return tmp;
}

L* DeletNode(L* cur)
{
    L* old = cur->front;

    old->next = cur->next;
    old->next->front = old;
    L* new = old->next;

    free(cur);
    return new;
}

int main()
{
    L l;
    L* prve = Init(0);
    L* count = prve;
    int n, m;
    scanf("%d%d", &n, &m);
    for (int i = 1; i <= n; i++)
    {
        L* tmp = Init(i);
        tmp->front = prve;
        prve->next = tmp;
        prve = tmp;
    }

    prve->next = count->next;
    count->next->front = prve;
    L* cur = prve->next;
    free(count);

    while (cur->next != cur)
    {
        for (int j = 0; j < m - 1; j++)
        {
            cur = cur->next;
        }
        cur = DeletNode(cur);
    }
    printf("%d", cur->val);

    return 0;
}

本人实力有限可能对一些地方解释和理解的不够清晰,可以自己尝试读代码,或者评论区指出错误,望海涵!

感谢大佬们的一键三连! 感谢大佬们的一键三连! 感谢大佬们的一键三连!

                                              数据结构:阶段测试(查漏补缺),数据结构练习,1024程序员节,c语言,开发语言,数据结构,c++,算法,单元测试文章来源地址https://www.toymoban.com/news/detail-720320.html

到了这里,关于数据结构:阶段测试(查漏补缺)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 查漏补缺 - ES6

    js 在 2015年发布了新版本,被称为 es6,之后每年更新一个版本。 自 es7 之后,就直接用年份命名了 。 版本 年份 es6 2015 es7 2016 es2017 2017 es2018 2018 下面如果用 var 会打印3个2。 指这个变量不能被修改 重新赋值,和修改这个对象的属性值是没有关系的。 自增 1,for…of 用于遍历可

    2024年02月09日
    浏览(28)
  • golang 编程规范查漏补缺

    公司最近出了 golang 语言规范,大部分参考 uber 的 go 语言规范(原版和翻译),以及官方的 Effective Go。这里分享一下自己之前没注意的点,查漏补缺 defer 和返回值赋值的执行顺序 对应知识点为方法返回值是有名还是无名的时候,defer 的顺序的差异 defer 和返回值之间的关系

    2024年02月07日
    浏览(39)
  • C++新经典 | C++ 查漏补缺(智能指针)

    目录 一、动态分配 1.初始化的三种方式 2. 释放内存 (1)悬空指针  3.创建新工程与观察内存泄漏 二、深入了解new/delete 1.new和delete 2.operator new()和operator delete() 3.申请和释放一个数组 三、智能指针  1.shared_ptr (1)常规初始化 (2)make_shared (3)引用计数 (3.1)引用计

    2024年02月07日
    浏览(25)
  • Android SystemUI 信号栏后添加信号图标,查漏补缺

    android:layout_width=“wrap_content” android:layout_marginStart=“1dp” android:visibility=“gone” android:tag=“mobile_slot_indicator_4” /      ImageView android:id=“@+id/custom_signal_4g” android:layout_height=“wrap_content” android:layout_width=“wrap_content” android:visibility=“gone” android:background=“@drawable/stat_sys

    2024年03月26日
    浏览(36)
  • 5种常用Web安全扫描工具,快来查漏补缺吧!

    漏洞扫描是一种安全检测行为,更是一类重要的网络安全技术,它能够有效提高网络的安全性,而且漏洞扫描属于主动的防范措施,可以很好地避免黑客攻击行为,做到防患于未然。那么好用的漏洞扫描工具有哪些? 答案就在本文! 1、AWVS Acunetix Web Vulnerability Scanner(简称

    2024年02月08日
    浏览(29)
  • Android-高级-UI-进阶之路-(二)-深入理解-Android-8-0-View-触摸事件分发机制,查漏补缺

    我们看到内部又调用了父类 dispatchTouchEvent 方法, 所以最终是交给 ViewGroup 顶级 View 来处理分发了。 顶级 View 对点击事件的分发过程 在上一小节中我们知道了一个事件的传递流程,这里我们就大致在回顾一下。首先点击事件到达顶级 ViewGroup 之后,会调用自身的 dispatchTouchE

    2024年04月14日
    浏览(58)
  • 【23考研】计算机408数据结构代码题强化阶段划重点(王道书)

    视频链接:【23考研】10分钟带你整理408数据结构强化阶段代码题复习重点 本篇只适合考408的同学,请自主命题的同学自觉右上角×掉 因为王道书为了照顾自主命题的同学,所以很多算法也给出了代码实现,实际上对于考408的同学,很多代码是不需要掌握的,毕竟408的代码题没

    2024年02月15日
    浏览(31)
  • <数据结构> 链表 - 小练习

    线性表在 ▁▁▁▁ 情况下适合采用链式存储结构。 A.线性表中数据元素的值需经常修改 B.线性表需经常插入或删除数据元素 C.线性表包含大量的数据元素 D.线性表的数据元素包含大量的数据项 链表要求内存中可用存储单元的地址 ▁▁▁▁▁ 。 A.必须是连续的 B.部分地址必

    2023年04月08日
    浏览(14)
  • 数据结构练习3

    一、单选(每小题1分,共20分) 1、下列叙述中错误的是( ). A、 循环队列空的条件是队头指针与队尾指针相同   B、 若二叉树没有叶子结点,则为空二叉树   C、 带链栈的栈底指针是随栈的操作而动态变化的   D、 若带链队列中只有一个元素,则队头指针与队尾指针必定相同  

    2024年01月25日
    浏览(26)
  • 【数据结构】第二章课后练习题——线性结构

    1、线性表是 一个有限序列,可以为空 2、链表中最常用的操作是在最后一个元素之后插入一个元素和删除最后一个元素,则采用 单循环链表 存储方式最节省运算时间 3、若某线性表中最常用的操作实在最后一个元素之后插入一个元素和删除第一个元素,则采用 仅有尾结点的

    2024年02月07日
    浏览(49)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包