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

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: 数据结构:阶段测试(查漏补缺)



选择题:

题一:

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)

思路一:

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

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

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

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)

思路一:

       构建值为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;
}

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

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

                                             

目录
相关文章
数据结构上机测试4.1:二叉树的遍历与应用1
数据结构上机测试4.1:二叉树的遍历与应用1
|
2月前
|
并行计算 算法 测试技术
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
65 1
|
3月前
|
分布式计算 Hadoop Unix
Hadoop-28 ZooKeeper集群 ZNode简介概念和测试 数据结构与监听机制 持久性节点 持久顺序节点 事务ID Watcher机制
Hadoop-28 ZooKeeper集群 ZNode简介概念和测试 数据结构与监听机制 持久性节点 持久顺序节点 事务ID Watcher机制
55 1
|
3月前
|
算法 Java 测试技术
数据结构 —— Java自定义代码实现顺序表,包含测试用例以及ArrayList的使用以及相关算法题
文章详细介绍了如何用Java自定义实现一个顺序表类,包括插入、删除、获取数据元素、求数据个数等功能,并对顺序表进行了测试,最后还提及了Java中自带的顺序表实现类ArrayList。
43 0
|
测试技术 KVM 开发工具
【OS Pintos】Pintos 内核库基本数据结构 | 运行测试用例 alarm-multiple
【OS Pintos】Pintos 内核库基本数据结构 | 运行测试用例 alarm-multiple
174 0
|
8月前
数据结构考试测试编程题
数据结构考试测试编程题
数据结构上机测试2-2:单链表操作B
数据结构上机测试2-2:单链表操作B
|
算法 Java 测试技术
【算法与数据结构】6 学会对算法进行性能测试
【算法与数据结构】6 学会对算法进行性能测试
190 0
【算法与数据结构】6 学会对算法进行性能测试
|
算法 安全 Java
【算法与数据结构】3 知行合一,线性查找的自定义类测试
【算法与数据结构】3 知行合一,线性查找的自定义类测试
105 0
数据结构134-二叉树插入测试代码
数据结构134-二叉树插入测试代码
69 0
数据结构134-二叉树插入测试代码