707. 设计链表(力扣刷题)(C语言题解)

2024-01-31 18:52

本文主要是介绍707. 设计链表(力扣刷题)(C语言题解),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

个人博客主页:https://blog.csdn.net/2301_79293429?type=blog
专栏:https://blog.csdn.net/2301_79293429/category_12545690.html

题目链接:

707. 设计链表 - 力扣(LeetCode)

该题为中等题,包括了对链表的大部分常用操作,更改真的很烦,因为它很长,链表题目也不方便调试,不知道哪里有问题,你只有一点一点的对比代码才找得到错哪

AC代码:

/*一定要建立虚拟头节点,方便的多--->统一操作,避免每次都要将头节点单独讨论*/typedef int VALTYPE;/*方便更改数据类型*//*链表的基本创建*/
typedef struct MyLinkedList {VALTYPE val;struct MyLinkedList* next;
}MyLinkedList;MyLinkedList* myLinkedListCreate() 
{MyLinkedList* head=(MyLinkedList*)malloc(sizeof(MyLinkedList));head->val=0;head->next=NULL;return head;
}int myLinkedListGet(MyLinkedList* obj, int index) 
{/*这里的obj是我们创建的虚拟头节点,所以要令p=obj->next*/MyLinkedList* p=obj->next;/*只是创建了一个指针变量,不需要动态开辟一块空间*/int i;for(i=0;p!=NULL;i++){if(i==index)return p->val;if(p->next==NULL)return -1;p=p->next;}return -1;
}void myLinkedListAddAtHead(MyLinkedList* obj, int val) 
{MyLinkedList* p1=(MyLinkedList*)malloc(sizeof(MyLinkedList));/*创建了一个结构体,需要动态开辟一块空间*/p1->val=val;p1->next=obj->next;/*注意顺序,要先将新节点的next指向obj的next,再更新obj的next*/obj->next=p1;
}void myLinkedListAddAtTail(MyLinkedList* obj, int val) 
{/*正确写法*/MyLinkedList* p=obj;/*不是obj->next了,因为也要对头节点进行判断是否为null*/for(int i=0;p->next!=NULL;i++){           /**/p=p->next;}MyLinkedList* p1=(MyLinkedList*)malloc(sizeof(MyLinkedList));p1->next=NULL;p1->val=val;p->next=p1;
}void myLinkedListAddAtIndex(MyLinkedList* obj, int index, int val) 
{if (index == 0) /**/{myLinkedListAddAtHead(obj, val);return;}MyLinkedList* p=obj->next;for(int i=1;p!=NULL;i++){/*要从1开始,0要特殊处理*/if(i==index){/*要等于index*/MyLinkedList* p2=(MyLinkedList*)malloc(sizeof(MyLinkedList));p2->val=val;p2->next=p->next;p->next=p2;return;/*直接return*/}p=p->next;}void myLinkedListDeleteAtIndex(MyLinkedList* obj, int index) 
{MyLinkedList* p=obj;for(int i=-1;p!=NULL&&p->next!=NULL;i++){if(i==index-1){MyLinkedList* temp=p->next;p->next=p->next->next;free(temp);break;}p=p->next;}
}void myLinkedListFree(MyLinkedList* obj) 
{struct MyLinkedList*p=obj->next;for(int i=0;p!=NULL;i++){struct MyLinkedList*temp=p;p=p->next;free(temp);}
}/*** Your MyLinkedList struct will be instantiated and called as such:* MyLinkedList* obj = myLinkedListCreate();* int param_1 = myLinkedListGet(obj, index);* myLinkedListAddAtHead(obj, val);* myLinkedListAddAtTail(obj, val);* myLinkedListAddAtIndex(obj, index, val);* myLinkedListDeleteAtIndex(obj, index);* myLinkedListFree(obj);
*/

最后祝大家题题AC,只盼做个WA梦 ~

这篇关于707. 设计链表(力扣刷题)(C语言题解)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/664737

相关文章

Linux链表操作方式

《Linux链表操作方式》:本文主要介绍Linux链表操作方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、链表基础概念与内核链表优势二、内核链表结构与宏解析三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势六、典型应用场景七、调试技巧与

Go语言中泄漏缓冲区的问题解决

《Go语言中泄漏缓冲区的问题解决》缓冲区是一种常见的数据结构,常被用于在不同的并发单元之间传递数据,然而,若缓冲区使用不当,就可能引发泄漏缓冲区问题,本文就来介绍一下问题的解决,感兴趣的可以了解一下... 目录引言泄漏缓冲区的基本概念代码示例:泄漏缓冲区的产生项目场景:Web 服务器中的请求缓冲场景描述代码

Go语言如何判断两张图片的相似度

《Go语言如何判断两张图片的相似度》这篇文章主要为大家详细介绍了Go语言如何中实现判断两张图片的相似度的两种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 在介绍技术细节前,我们先来看看图片对比在哪些场景下可以用得到:图片去重:自动删除重复图片,为存储空间"瘦身"。想象你是一个

Go语言中Recover机制的使用

《Go语言中Recover机制的使用》Go语言的recover机制通过defer函数捕获panic,实现异常恢复与程序稳定性,具有一定的参考价值,感兴趣的可以了解一下... 目录引言Recover 的基本概念基本代码示例简单的 Recover 示例嵌套函数中的 Recover项目场景中的应用Web 服务器中

MyBatis设计SQL返回布尔值(Boolean)的常见方法

《MyBatis设计SQL返回布尔值(Boolean)的常见方法》这篇文章主要为大家详细介绍了MyBatis设计SQL返回布尔值(Boolean)的几种常见方法,文中的示例代码讲解详细,感兴趣的小伙伴... 目录方案一:使用COUNT查询存在性(推荐)方案二:条件表达式直接返回布尔方案三:存在性检查(EXI

Go语言中使用JWT进行身份验证的几种方式

《Go语言中使用JWT进行身份验证的几种方式》本文主要介绍了Go语言中使用JWT进行身份验证的几种方式,包括dgrijalva/jwt-go、golang-jwt/jwt、lestrrat-go/jw... 目录简介1. github.com/dgrijalva/jwt-go安装:使用示例:解释:2. gi

Go 语言中的 Struct Tag 的用法详解

《Go语言中的StructTag的用法详解》在Go语言中,结构体字段标签(StructTag)是一种用于给字段添加元信息(metadata)的机制,常用于序列化(如JSON、XML)、ORM映... 目录一、结构体标签的基本语法二、json:"token"的具体含义三、常见的标签格式变体四、使用示例五、使用

Go语言使用slices包轻松实现排序功能

《Go语言使用slices包轻松实现排序功能》在Go语言开发中,对数据进行排序是常见的需求,Go1.18版本引入的slices包提供了简洁高效的排序解决方案,支持内置类型和用户自定义类型的排序操作,本... 目录一、内置类型排序:字符串与整数的应用1. 字符串切片排序2. 整数切片排序二、检查切片排序状态:

基于Go语言实现Base62编码的三种方式以及对比分析

《基于Go语言实现Base62编码的三种方式以及对比分析》Base62编码是一种在字符编码中使用62个字符的编码方式,在计算机科学中,,Go语言是一种静态类型、编译型语言,它由Google开发并开源,... 目录一、标准库现状与解决方案1. 标准库对比表2. 解决方案完整实现代码(含边界处理)二、关键实现细

如何合理管控Java语言的异常

《如何合理管控Java语言的异常》:本文主要介绍如何合理管控Java语言的异常问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、介绍2、Thorwable类3、Error4、Exception类4.1、检查异常4.2、运行时异常5、处理方式5.1. 捕获异常