码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 数据结构:阶段测试(查漏补缺)


    目录

    选择题:

    题一:

    题二:

    题三:

    题四:

    编程题:

    题一:左叶子之和

    思路一:

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

    思路一:

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

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


    选择题:

    题一:

    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)

    思路一:

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

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

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

    1. int sumOfLeftLeaves(struct TreeNode* root )
    2. {
    3. if(root == NULL)
    4. {
    5. return 0;
    6. }
    7. int sum = 0;
    8. if(root->left && root->left->left == NULL && root->left->right == NULL)
    9. {
    10. sum += root->left->val;
    11. }
    12. sum += sumOfLeftLeaves(root->left) + sumOfLeftLeaves(root->right);
    13. return sum;
    14. }

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

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

    思路一:

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

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

    1. #define _CRT_SECURE_NO_WARNINGS 1
    2. //约瑟夫问题
    3. #include
    4. typedef struct List
    5. {
    6. struct List* front;
    7. int val;
    8. struct List* next;
    9. }L;
    10. L* Init(int x)
    11. {
    12. L* tmp = (L*)malloc(sizeof(L));
    13. tmp->val = x;
    14. tmp->next = NULL;
    15. tmp->front = NULL;
    16. return tmp;
    17. }
    18. L* DeletNode(L* cur)
    19. {
    20. L* old = cur->front;
    21. old->next = cur->next;
    22. old->next->front = old;
    23. L* new = old->next;
    24. free(cur);
    25. return new;
    26. }
    27. int main()
    28. {
    29. L l;
    30. L* prve = Init(0);
    31. L* count = prve;
    32. int n, m;
    33. scanf("%d%d", &n, &m);
    34. for (int i = 1; i <= n; i++)
    35. {
    36. L* tmp = Init(i);
    37. tmp->front = prve;
    38. prve->next = tmp;
    39. prve = tmp;
    40. }
    41. prve->next = count->next;
    42. count->next->front = prve;
    43. L* cur = prve->next;
    44. free(count);
    45. while (cur->next != cur)
    46. {
    47. for (int j = 0; j < m - 1; j++)
    48. {
    49. cur = cur->next;
    50. }
    51. cur = DeletNode(cur);
    52. }
    53. printf("%d", cur->val);
    54. return 0;
    55. }

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

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

                                                  

  • 相关阅读:
    NR 物理层编码 卷积码8-slide
    【公式输入】 latex和markdown支持的公式写法整理
    eNSP实现 telnet 和 ssh 远程登录及抓包
    二叉树的最近公共祖先
    基于Python Django的公务员考试信息管理系统
    软件设计模式系列之五——建造者模式
    Swagger ui接口自动化批量漏洞测试
    代码随想录算法训练营Day50 | 123.买卖股票的最佳时机III,188.买卖股票的最佳时机IV
    原生M1/M2 Photoshop 2022 for Mac(PS2022)v23.4.2 中英文正式发布详情介绍&安装教程
    【14】基础知识:React - redux
  • 原文地址:https://blog.csdn.net/weixin_71964780/article/details/134022470
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号