寒假作业Day 10

寒假作业Day 10

一、选择题

1、下列数据结构中,不属于线性表的是( )
A.队列 B.顺序表 C.二叉树 D.链表

A. 队列:队列是一种特殊的线性表,它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作。因此,队列是线性表。
B. 顺序表:顺序表是用一段地址连续的存储单元依次存储线性表的数据元素。它也是线性表的一种实现方式。
C. 二叉树:二叉树是每个节点最多有两个子节点的树结构,通常子节点被称作“左孩子”和“右孩子”。二叉树并不是线性表,因为它的元素不是按照线性顺序排列的。
D. 链表:链表是一种物理存储单元上非连续的、非顺序的线性数据结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的。因此,链表也是线性表的一种实现方式。

2、对于一个头指针为 head 的带头结点的单链表,判断该表为空的条件是( )
A. head=NULL B. head→next==NULL C. head→next=head D. head!=NULL

因为头节点只是哨兵位,是不参与单链表的增删查改的,所以头节点的下一个节点才是真正的头节点,所以判断该表为空的条件为head->next==NULL

3、当线性表的元素总数基本稳定,且很少进行插入和删除操作,但要求以最快的速度存取线性表中的元素时,应采用什么存储结构?( )
A. 顺序表 B. 单链表 C. 循环链表 D. 双链表

因为要以最快的速度存取元素,并且很少插入和删除,所以我们选择顺序表,因为其他几个链表都需要遍历才可以存取元素,而顺序表可以直接通过下标查找

在这里插入图片描述

这个画图可以很清晰噢~
在这里插入图片描述
把head当作L指向的内容,而3当作p指向的内容,那么很明显,p->next==L,L->prior ==p

在这里插入图片描述

选择C噢,要先把新节点跟旧节点后面的节点连接起来,再把新节点与旧节点连接起来,不然会丢掉后续节点

二、编程题

在这里插入图片描述

int search(int* nums, int numsSize, int target) {  
    int n = numsSize;  
      
    // 如果数组为空,则直接返回-1表示未找到目标值  
    if (!n) {  
        return -1;  
    }  
      
    // 如果数组只有一个元素,直接判断这个元素是否等于目标值  
    if (n == 1) {  
        return nums[0] == target ? 0 : -1;  
    }  
      
    // 定义搜索范围的起始和结束索引  
    int begin = 0, end = n - 1;  
      
    // 当搜索范围有效时继续循环  
    while (begin <= end) {  
        // 计算中间元素的索引  
        int mid = (begin + end) / 2;  
          
        // 如果中间元素等于目标值,直接返回其索引  
        if (nums[mid] == target) return mid;  
          
        // 检查左侧部分是否是有序的  
        if (nums[0] <= nums[mid]) {  
            // 如果目标值在有序部分的范围内,更新结束索引  
            if (nums[0] <= target && target < nums[mid]) {  
                end = mid - 1;  
            } else {  
                // 否则,更新起始索引  
                begin = mid + 1;  
            }  
        } else {  
            // 检查右侧部分是否是有序的  
            // 如果目标值在有序部分的范围内,更新起始索引  
            if (nums[mid] < target && target <= nums[n - 1]) {  
                begin = mid + 1;  
            } else {  
                // 否则,更新结束索引  
                end = mid - 1;  
            }  
        }  
    }  
      
    // 如果循环结束还没有找到目标值,则返回-1  
    return -1;  
}

在这里插入图片描述

int getDecimalValue(struct ListNode* head) {
    ListNode* phead=head;
    int count=0;  
    int result=0;  
    
    while(phead){
        count++;//遍历链表先记录有多少个节点
        phead=phead->next;
    }

    phead=head;//刷新位置
    while(phead){
        if(phead->val==1)
            result+=pow(2,count-1);//遍历的同时加值,count-1的原因是因为假如有3个节点,101,最高的位置也是2^2,而非2^3,这是需要注意的问题

        count--;//次方逐步下降
        phead=phead->next;
    }

    return result;
}

这是简单粗暴的解法,很容易看出,它的时间复杂度是O(N^2),过于高,如果数据过大,效率很受影响,所以我们还有另外一种解法

int getDecimalValue(ListNode* head) {
        ListNode* cur = head;
        int ans = 0;
        while (cur != NULL) {
            ans = ans * 2 + cur->val;
            cur = cur->next;
        }
        return ans;
}

很明显可以看出,这里的时间复杂度就只有O(N)了,它是从最高位开始,在遍历的过程逐步乘2;比如101,第一个1乘了2次,第2个0乘了1次,第三个1乘了0次,也就是按照原本的值计算,这是一种更加巧妙的方法,虽然一开始不容易想到,但是效率高了很多

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/445642.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【经管数据-更新】华证ESG评级得分数据(2009-2023年)

一、数据说明 参考《经济研究》中方先明&#xff08;2023&#xff09;的做法&#xff0c;将华证ESG评级进行赋值&#xff0c;指标包含C、CC、CCC、B、BB、BBB、A、AA、AAA共9个等级&#xff0c;将上市公司ESG 等级从低到高分别赋值为1至9 二、数据来源&#xff1a;世界银行&am…

Springboot进行web开发

创建springboot工程&#xff0c;基于2022版idea pom.xml文件中的插件爆红&#xff1a; 解决方法&#xff1a;给插件加<version>版本号</version> 版本号和<parent></parent>中的版本号一样。 另外有人说重启也可以解决爆红&#xff0c;可以试一下&a…

Stable diffusion(一)

Stable diffusion 原理解读 名词解释 正向扩散&#xff08;Fixed Forward Diffusion Process&#xff09;&#xff1a;反向扩散&#xff08;Generative Reverse Denoising Process&#xff09; VAE&#xff08;Variational AutoEncoder&#xff09;&#xff1a;一个用于压缩图…

【动态规划】【前缀和】【和式变换】100216. K 个不相交子数组的最大能量值

本文涉及知识点 动态规划汇总 C算法&#xff1a;前缀和、前缀乘积、前缀异或的原理、源码及测试用例 包括课程视频 LeetCode 100216. K 个不相交子数组的最大能量值 给你一个长度为 n 下标从 0 开始的整数数组 nums 和一个 正奇数 整数 k 。 x 个子数组的能量值定义为 stren…

Swagger修改Api文档中的数据类型

swagger不陌生,API接口利器,本次要解决的问题是:我们知道前端在接收Long类型的属性时会出现精度问题,一般我们会在序列化的时候将Long类型的数字转换成String但是swagger的API文档中的类型还是Long,我们要解决的就是这个问题 不知道swagger怎么配置得可以看之前的文章:springb…

空间复杂度的OJ练习——轮转数组

旋转数组OJ链接&#xff1a;https://leetcode-cn.com/problems/rotate-array/ 题目&#xff1a; 思路&#xff1a; 通过题目我们可以知道这是一个无序数组&#xff0c;只需要将数组中的数按给定条件重新排列&#xff0c;因此我们可以想到以下几种方法&#xff1a; 1.暴力求解法…

【Tauri】(5):本地运行candle和 qwen 大模型,并测试速度

1&#xff0c;本地运行candle 关于candle项目 https://github.com/huggingface/candle Hugging Face 使用rust开发的高性能推理框架。 语法简单&#xff0c; 风格与 PyTorch 相似。 CPU 和 Cuda Backend&#xff1a;m1、f16、bf16。 支持 Serverless&#xff08;CPU&#xff…

React 从0到1构建企业级框架基于Antd Designer

一、 create-react-app 创建 cms-front 二、 删除不必须要的文件形成如下结构 1. React版本为17版本 public 文件夹下保留 favicon.ico 偏爱图标index.html资源文件 2.src 保留 index.js 入口文件和app.js(基于spa原则)单文件即可 三、配置eslint 1. 安装 eslint. npm inst…

章六、集合(1)—— Set 接口及实现类、集合迭代、Map 接口、Collections类

一、 Set 接口及实现类 Set接口不能存储重复元素 Set接口继承了Collection接口。Set中所存储的元素是不重复的,但是是无序的, Set中的元素是没有索引的 Set接口有两个实现类&#xff1a; ● HashSet &#xff1a;HashSet类中的元素不能重复 ● TreeSet &#xff1a;可以给Set集…

低密度奇偶校验码LDPC(十)——LDPC码的密度进化

一、密度进化的概念 二、规则LDPC码的密度进化算法(SPA算法) 算法变量表 VN更新的密度进化 CN更新的密度进化 算法总结 程序仿真 参考文献 [1] 白宝明 孙韶辉 王加庆. 5G 移动通信中的信道编码[M]. 北京: 电子工业出版社, 2018. [2] William E. Ryan, Shu Lin. Channel Co…

Spring-AOP基础(全在这里)

八股文部分来源于网络&#xff0c;例子为原创 OOP(Object-oriented programming) 也就是面向对象编程&#xff0c;继承&#xff0c;封装&#xff0c;多态。 局限性 静态语言&#xff1a;类结构一旦定义&#xff0c;不容易被修改(并不是无法修改)。只能侵入性扩展&#xff1a…

太强了!最全的大模型检索增强生成(RAG)技术概览!

本文是对检索增强生成&#xff08;Retrieval Augmented Generation, RAG&#xff09;技术和算法的全面研究&#xff0c;对各种方法进行了系统性的梳理。文章中还包含了我知识库中提到的各种实现和研究的链接集合。 鉴于本文的目标是对现有的RAG算法和技术进行概览和解释&#…

【深度学习笔记】6_5 RNN的pytorch实现

注&#xff1a;本文为《动手学深度学习》开源内容&#xff0c;部分标注了个人理解&#xff0c;仅为个人学习记录&#xff0c;无抄袭搬运意图 6.5 循环神经网络的简洁实现 本节将使用PyTorch来更简洁地实现基于循环神经网络的语言模型。首先&#xff0c;我们读取周杰伦专辑歌词…

【C++】list模拟实现list迭代器失效问题

list模拟实现&list迭代器失效问题 一&#xff0c;list模拟实现1. list的主要框架接口模拟2. list构造&拷贝构造&析构3. list迭代器3.1 普通迭代器3.2 const迭代器 4. 增删查改 二&#xff0c;迭代器失效问题1. list的迭代器失效原因2. 解决办法 一&#xff0c;list…

个推与华为深度合作,成为首批支持兼容HarmonyOS NEXT的服务商

自华为官方宣布HarmonyOS NEXT鸿蒙星河版开放申请以来&#xff0c;越来越多的头部APP宣布启动鸿蒙原生开发&#xff0c;鸿蒙生态也随之进入全新发展的第二阶段。 作为华为鸿蒙生态的重要合作伙伴&#xff0c;个推一直积极参与鸿蒙生态建设。为帮助用户在HarmonyOS NEXT上持续享…

PostGIS 中的 K-Means 聚类操作及应用

K-Means算法&#xff1a; K-means 是数据科学和商业的基本算法。让我们深入了解一下。 1. K-means是一种流行的用于聚类的无监督机器学习算法。它是用于客户细分、库存分类、市场细分甚至异常检测的核心算法。 2. 无监督&#xff1a;K-means 是一种无监督算法&#xff0c;用于…

《MySQL数据库》day2--连接查询、子查询、union、limit、DML语句

文章目录 1.把查询结果去除重复记录 -》distinct2.连接查询2.1什么是连接查询&#xff1f;2.2连接查询的分类2.3笛卡尔积现象2.4内连接2.4.1内连接之等值连接。2.4.2内连接之非等值连接2.4.3内连接之自连接 2.5外连接2.6三张表&#xff0c;四张表怎么连接&#xff1f; 3.子查询…

从0到1入门C++编程——11 函数对象及算法介绍

文章目录 函数对象1、谓词2、内建函数对象(1) 算术仿函数(2) 关系仿函数(3) 逻辑仿函数 常用算法1、常用遍历算法(1) for_each(2) transform 2、常用查找算法(1) find和find_if(2) find_if(3) adjacent_find(4) binary_search(5) count(6) count_if 3、常用排序算法(1) sort(2)…

奇舞周刊第521期:实现vue3响应式系统核心-MVP 模型

奇舞推荐 ■ ■ ■ 实现vue3响应式系统核心-MVP 模型 手把手带你实现一个 vue3 响应式系统&#xff0c;代码并没有按照源码的方式去进行组织&#xff0c;目的是学习、实现 vue3 响应式系统的核心&#xff0c;用最少的代码去实现最核心的能力&#xff0c;减少我们的学习负担&…

序列化相关知识总结

目录 一、序列化1.1 基本概念1.1.1 序列化1.1.2 反序列化1.1.3 数据结构、对象与二进制串1.1.4 序列化/反序列化的目的 1.2 几种常见的序列化和反序列化协议1.2.1 XML&SOAP1.2.2 JSON&#xff08;Javascript Object Notation&#xff09;1.2.3 Protobuf 二、安卓下的序列化…