请问有人会数据结构嘛?这个咋写呀?

清酒儿 2021-03-08 05:17:22
用c写一个 删除单链表中值为key的第一个结点:查找值为key的结点是否存在,若存在,则删除;否则返回NULL。
...全文
154 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
赵4老师 2021-03-10
  • 打赏
  • 举报
回复
数据结构对单链表进行数据排序 http://bbs.csdn.net/topics/392201633
qzjhjxj 2021-03-10
  • 打赏
  • 举报
回复
熊猫呀 2021-03-10
  • 打赏
  • 举报
回复
这种问题 可以问 你们班 男同学 请给他一个机会。
羅昇 2021-03-10
  • 打赏
  • 举报
回复
程序媛这待遇可以啊
清酒儿 2021-03-09
  • 打赏
  • 举报
回复
引用 2 楼 paena的回复:
给你写个吧。可直接运行
#include<stdio.h>
#include<stdlib.h>
typedef int ElemType; //可根据实际修改变量类型 
typedef int Index; //索引号的类型 
//单链表结点定义 
typedef struct node{ElemType data;struct node *next;}LinkNode;
//定义单链表 
typedef struct{LinkNode* firstnode;int length;} LinkList;

LinkNode* RemoveElem(LinkList* pL,ElemType e)
{
	LinkNode* p = pL->firstnode;
	LinkNode* pp = NULL; //表示p的前驱 
	for(int i = 0; i < pL->length;i++)
	{
		if(p->data == e)
			if(pp==NULL)//执行删除首节点
			{
				pL->firstnode = pL->firstnode->next;
				pL->length--;
				return p;
			} 
			else //删除节点,利用pp接上链表 
			{
				pp->next = p->next;
				pL->length--;
				return p;
			}
		pp=p; //赋值前驱 
		p = p->next;
	}
	return NULL; //执行到这里,说明没有找到与e相等的节点数据 
}

int ListInsert(LinkList* pL, Index i,ElemType e)
{
	if(i<0 || i> pL->length)
		return -1;
	LinkNode* newnode = malloc(sizeof(LinkNode));
	if(newnode == NULL)
		return -2;
	newnode->data = e;
	if(i == 0)
	{
		newnode->next = pL->firstnode;
		pL->firstnode = newnode;
	}
	else
	{
		LinkNode* p = pL->firstnode;
		for(int j=0; j < i-1; j++)
			p = p->next;
		newnode->next = p->next;
		p->next = newnode;
	}
	pL->length++;
	return 0;
}

void ListTraverse(LinkList L) //链表遍历操作
{
	if(L.firstnode == NULL)
	{
		printf("\n\nTraverse: LinkList is NULL!\n");
		return;
	}
	printf("\n\nTraverse LinkList Elements, length is %d",L.length);
	printf("\n-------------------------------------------------------------------");
	printf("\nIndex \tNodeAddr \tNodeData\tNodeNext");
	printf("\n-------------------------------------------------------------------");	
	int i = 0;
	for(LinkNode* p = L.firstnode;p!=NULL;p=p->next,i++)
		printf("\n%d \t%#X \t%d \t\t0X%X",i,p,p->data,p->next);
}

int main()
{
	LinkList L= {NULL,0};
	ListTraverse(L);
	for(int i=0;i<10;i++)	//循环插入数据,倒序排列 
		ListInsert(&L,0,i); //总是在链表头插入 
	ListTraverse(L); //插入数据后,输出单链表 
	for(int i=0;i<10;i++) //循环插入数据,正序排列
		ListInsert(&L,L.length,i); //总是在链表尾部插入
	ListTraverse(L); //插入数据后,输出单链表
	LinkNode* p=RemoveElem(&L,9);
	free(p);
	ListTraverse(L); //删除数据后,输出单链表
	//显式销毁整个链表,当然进程退出,也会自动销毁 
	return 0;
}
谢谢大佬很感谢您和一楼的大佬,谢谢
清酒儿 2021-03-09
  • 打赏
  • 举报
回复
引用 1 楼 墨梅无痕的回复:

/* 
========================== 
 功能:删除指定节点 
  (此例中是删除指定学号的节点) 
 返回:指向链表表头的指针 
========================== 
*/  
struct student *Del (struct student *head, int num)  
{  
    struct student *p1;     //p1保存当前需要检查的节点的地址  
    struct student *p2;     //p2保存当前检查过的节点的地址  
    if (head == NULL)       //是空链表(结合图3理解)  
    {  
        printf ("\nList is null!\n");  
        return head;  
    }  
  
    //定位要删除的节点  
    p1 = head;  
    while (p1->num != num && p1->next != NULL)    //p1指向的节点不是所要查找的,并且它不是最后一个节点,就继续往下找  
    {  
        p2 = p1;            //保存当前节点的地址  
        p1 = p1->next;       //后移一个节点  
    }  
  
    if(p1->num==num)     //找到了。(结合图4、5理解)  
    {  
        if (p1 == head)     //如果要删除的节点是第一个节点  
        {  
            head = p1->next; //头指针指向第一个节点的后一个节点,也就是第二个节点。这样第一个节点就不在链表中,即删除  
        }  
        else            //如果是其它节点,则让原来指向当前节点的指针,指向它的下一个节点,完成删除  
        {  
            p2->next = p1->next;  
        }  
  
        free (p1);      //释放当前节点  
        p1 = NULL;  
        printf ("\ndelete %ld success!\n", num);  
        n -= 1;         //节点总数减1个  
    }  
    else                //没有找到  
    {  
        printf ("\n%ld not been found!\n", num);  
    }  
  
    return head;  
}  
在CSDN里搜一搜么,一大堆,关键字:C语言 链表。
谢谢您,我是刚刚接触计算机,老师催作业催的急,我理解东西慢,我会努力的
paena 2021-03-09
  • 打赏
  • 举报
回复
给你写个吧。可直接运行
#include<stdio.h>
#include<stdlib.h>
typedef int ElemType; //可根据实际修改变量类型 
typedef int Index; //索引号的类型 
//单链表结点定义 
typedef struct node{ElemType data;struct node *next;}LinkNode;
//定义单链表 
typedef struct{LinkNode* firstnode;int length;} LinkList;

LinkNode* RemoveElem(LinkList* pL,ElemType e)
{
	LinkNode* p = pL->firstnode;
	LinkNode* pp = NULL; //表示p的前驱 
	for(int i = 0; i < pL->length;i++)
	{
		if(p->data == e)
			if(pp==NULL)//执行删除首节点
			{
				pL->firstnode = pL->firstnode->next;
				pL->length--;
				return p;
			} 
			else //删除节点,利用pp接上链表 
			{
				pp->next = p->next;
				pL->length--;
				return p;
			}
		pp=p; //赋值前驱 
		p = p->next;
	}
	return NULL; //执行到这里,说明没有找到与e相等的节点数据 
}

int ListInsert(LinkList* pL, Index i,ElemType e)
{
	if(i<0 || i> pL->length)
		return -1;
	LinkNode* newnode = malloc(sizeof(LinkNode));
	if(newnode == NULL)
		return -2;
	newnode->data = e;
	if(i == 0)
	{
		newnode->next = pL->firstnode;
		pL->firstnode = newnode;
	}
	else
	{
		LinkNode* p = pL->firstnode;
		for(int j=0; j < i-1; j++)
			p = p->next;
		newnode->next = p->next;
		p->next = newnode;
	}
	pL->length++;
	return 0;
}

void ListTraverse(LinkList L) //链表遍历操作
{
	if(L.firstnode == NULL)
	{
		printf("\n\nTraverse: LinkList is NULL!\n");
		return;
	}
	printf("\n\nTraverse LinkList Elements, length is %d",L.length);
	printf("\n-------------------------------------------------------------------");
	printf("\nIndex \tNodeAddr \tNodeData\tNodeNext");
	printf("\n-------------------------------------------------------------------");	
	int i = 0;
	for(LinkNode* p = L.firstnode;p!=NULL;p=p->next,i++)
		printf("\n%d \t%#X \t%d \t\t0X%X",i,p,p->data,p->next);
}

int main()
{
	LinkList L= {NULL,0};
	ListTraverse(L);
	for(int i=0;i<10;i++)	//循环插入数据,倒序排列 
		ListInsert(&L,0,i); //总是在链表头插入 
	ListTraverse(L); //插入数据后,输出单链表 
	for(int i=0;i<10;i++) //循环插入数据,正序排列
		ListInsert(&L,L.length,i); //总是在链表尾部插入
	ListTraverse(L); //插入数据后,输出单链表
	LinkNode* p=RemoveElem(&L,9);
	free(p);
	ListTraverse(L); //删除数据后,输出单链表
	//显式销毁整个链表,当然进程退出,也会自动销毁 
	return 0;
}
墨梅无痕 2021-03-08
  • 打赏
  • 举报
回复

/* 
========================== 
 功能:删除指定节点 
  (此例中是删除指定学号的节点) 
 返回:指向链表表头的指针 
========================== 
*/  
struct student *Del (struct student *head, int num)  
{  
    struct student *p1;     //p1保存当前需要检查的节点的地址  
    struct student *p2;     //p2保存当前检查过的节点的地址  
    if (head == NULL)       //是空链表(结合图3理解)  
    {  
        printf ("\nList is null!\n");  
        return head;  
    }  
  
    //定位要删除的节点  
    p1 = head;  
    while (p1->num != num && p1->next != NULL)    //p1指向的节点不是所要查找的,并且它不是最后一个节点,就继续往下找  
    {  
        p2 = p1;            //保存当前节点的地址  
        p1 = p1->next;       //后移一个节点  
    }  
  
    if(p1->num==num)     //找到了。(结合图4、5理解)  
    {  
        if (p1 == head)     //如果要删除的节点是第一个节点  
        {  
            head = p1->next; //头指针指向第一个节点的后一个节点,也就是第二个节点。这样第一个节点就不在链表中,即删除  
        }  
        else            //如果是其它节点,则让原来指向当前节点的指针,指向它的下一个节点,完成删除  
        {  
            p2->next = p1->next;  
        }  
  
        free (p1);      //释放当前节点  
        p1 = NULL;  
        printf ("\ndelete %ld success!\n", num);  
        n -= 1;         //节点总数减1个  
    }  
    else                //没有找到  
    {  
        printf ("\n%ld not been found!\n", num);  
    }  
  
    return head;  
}  
在CSDN里搜一搜么,一大堆,关键字:C语言 链表。
酷窗版演示:http://www.edd8.com/bbs/index.asp?style=0 简装版演示:http://www.edd8.com/bbs/index2.asp 一点点论坛(http://www.edd8.com/bbs)使用说明 欢迎大家下载使用一点点论坛,在使用论坛前,请认真阅读以下内容: ===================================== 论坛:一点点论坛(http://www.edd8.com/bbs) 主页:一点点星空驿站(http://www.edd8.com/) 站长:叮咚虫(e_Mail:b_li@163.com) 版本:EDD8 Ver.2003 for DV =====================================   一点点论坛是建立在动网论坛基础上的ASP互动论坛,从动网Var5.b109开始论坛结构便开始脱离动网,与动网升级一起,本论坛本身也同时实现了动网新的功能,到519的发布,本人常得论坛本身已功能基本完善,所以决定与动网完全脱离,到动网Final的出现,本论坛也决定不再跟随动网升级了,本人全面对原来的论坛进行了代码优化和版面重排,并升级了部分功能代码,完成了现在这样的论坛。使论坛已经完全脱离了动网,以后也不可以随动网一起升级了!   所以选择本论坛的朋友请先明白,如果采用了本论坛的数据结构,以后就不可以和动网一起升级了,而现有的动网Final版的数据库和本论坛的数据库也是不兼容的!对于动网V5.b519的用户,本人同时在压缩包里提供了升级文件,可以把你519的数据库升级成和本论坛一致的数据结构!   由于一些朋友催得较急,部分功能还是没有完善的(但不出错),我以后也给出升级包的。所以决定使用本论坛的朋友,请一定要到本站论坛的“站务办公室”进行指定的留言签名,以好我第一时间通知大家升级!   论坛中使用到的部分插件并没有一同奉上,原因是我还没完成代码优化,请过几天到我的论坛上下载。可以下载的插件主要有:社区银行、网络拳皇、可乐吧台球、五子棋等等…… ===================================== 主要特色功能说明: ◎ 双版面设计,用户可以根据不同爱好选择不同的版式(酷窗版和精简版),系统记录用户的选择,不用重复选择,也不出现版面混淆等现象; ◎ 发贴回贴互动功能,给用户随机的互动事件,增加用户的参与兴趣; ◎ 增强的UBB代码和JS代码,新增的买卖贴、定时贴等十几种特色功能UBB代码; ◎ 贴子功能加强,增加互动鲜花、鸡蛋、金钱、炸弹等功能,并保存数据作为用户在论坛的人缘依据; ◎ 不好说了,等你去发掘吧,不然又说我叫卖了…… ====================================== 安装说明: 解压就可以了,数据库名称和路径有变动时不要忘了在CONN。ASP中进行相应修改。 (注意:当论坛中一个贴子也没有时,论坛明星出错,但当你加入贴子后就正常了,大家不要惊慌) 升级:(对519),解压后把你的原519数据库覆盖现数据库,再执行根目录下的UPDATE。ASP文件就行了,如果没有升级成功的提示,说明你的数据不能进行升级! (注意:数据库的升级应做了备份,并在本机上进行!) ====================================== 最后一点说明: 由于论坛本来是打算自己用的,所以在设计的过程中部分变量已经去掉,不能从后台设置了(如表格边框),请大家最好保持现有的风格。 如果还不问题,可以到我的论坛上来交流。??注意,由于本人时间不限,技术支持是有限的,请不要过于强求!

33,318

社区成员

发帖
与我相关
我的任务
社区描述
C/C++ 新手乐园
社区管理员
  • 新手乐园社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧