双向链表

Time Limit: 1000ms   Memory limit: 65536K  有疑问?点这里^_^

题目描述

学会了单向链表,我们又多了一种解决问题的能力,单链表利用一个指针就能在内存中找到下一个位置,这是一个不会轻易断裂的链。但单链表有一个弱点——不能回指。比如在链表中有两个节点A,B,他们的关系是B是A的后继,A指向了B,便能轻易经A找到B,但从B却不能找到A。一个简单的想法便能轻易解决这个问题——建立双向链表。在双向链表中,A有一个指针指向了节点B,同时,B又有一个指向A的指针。这样不仅能从链表头节点的位置遍历整个链表所有节点,也能从链表尾节点开始遍历所有节点。对于给定的一列数据,按照给定的顺序建立双向链表,按照关键字找到相应节点,输出此节点的前驱节点关键字及后继节点关键字。

输入

第一行两个正整数n(代表节点个数),m(代表要找的关键字的个数)。接下来n行每行有一个整数为关键字key(数据保证关键字在数列中没有重复)。接下来有m个关键字,每个占一行。

输出

对给定的每个关键字,输出此关键字前驱节点关键字和后继节点关键字。如果给定的关键字没有前驱或者后继,则不输出。给定关键字为每个输出占一行。

示例输入

10 3
1 2 3 4 5 6 7 8 9 0
3
5
0

示例输出

2 4
4 6
9

提示

 代码:

//双向链表的基本操作:建表,删除,插入  

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <algorithm> using namespace std; struct node
{
int date;
struct node *next;
struct node *pre;
}; //双向链表的建表(顺序创建具有n个节点的双向链表) struct node *Creat_list(int n)
{
int i;
struct node *head, *tail, *p;
head = new struct node;
head->next=NULL;
head->pre=NULL; //架空head
tail=head; for(i=0; i<n; i++)
{
p=new struct node;
scanf("%d", & p->date );
p->next=NULL;
p->pre=NULL;
//一个带有数据的节点创建成功
tail->next=p;
p->pre=tail;
tail=p;
}
return head;
} int main()
{
struct node *head, *p;
int n, m;
scanf("%d %d", &n, &m); head = Creat_list(n);
int i, dd; for(i=0; i<m; i++)
{
scanf("%d", &dd);
p=head->next;
while(p)
{
if(p->date == dd)
{
break;
}
p=p->next;
}
int flag=0;
if(p->pre!=head)
{
printf("%d", p->pre->date );
flag=1;
}
if(p->next)
{
if(flag==1)
printf(" %d", p->next->date );
else
printf("%d", p->next->date );
}
printf("\n");
}
return 0;
} /* 双向链表的模板!!!
//双向链表的基本操作:建表,删除,插入 #include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <algorithm> using namespace std; struct node
{
int date;
struct node *next;
struct node *pre;
}; //双向链表的建表(顺序创建具有n个节点的双向链表) struct node *Creat_list(int n)
{
int i;
struct node *head, *tail, *p;
head = new struct node;
head->next=NULL;
head->pre=NULL; //架空head
tail=head; for(i=0; i<n; i++)
{
p=new struct node;
scanf("%d", & p->date );
p->next=NULL;
p->pre=NULL;
//一个带有数据的节点创建成功
tail->next=p;
p->pre=tail;
tail=p;
}
return head;
} //双向链表中 删除数据值为key的所指节点元素 struct node *Delete(struct node *head, int key)
{
struct node *p;
p=head->next;
while( p )
{
if(p->date == key )
{
p->pre->next=p->next;
if(p->next)
{
p->next->pre=p->pre;
}
//break;
}
p=p->next; //注意对应的那
} return head;
} //在该双向链表的 第pos个位置之后 插入 值为key的节点元素 (在首(第一个元素的位置)和尾(最后一个元素)插入容易出现bug, 所以需要注意)
struct node *Insert(struct node *head, int pos, int key )
{
struct node *p;
p=head->next; struct node *q;
q=new struct node;
q->date=key; q->next=NULL; q->pre=NULL; //创建要插入的节点 int cnt=0; //计数变量 if(pos==0) //特殊情况,如果我们想在最前面进行插入
{
if(head->next)
{
head->next->pre=q; q->next=head->next;
head->next=q; q->pre=head;
}
else
{
head->next=q; q->pre=head;
}
}
else
{
while(p)
{
cnt++;
if(cnt==pos)
{
break;
}
p=p->next;
}
if(p->next)
{
p->next->pre=q; q->next=p->next;
p->next=q; q->pre=p;
}
else
{
p->next=q; q->pre=p;
}
}
return head;
} int main()
{
struct node *head, *p;
int n;
scanf("%d", &n);
head = Creat_list(n); //创建双向链表
p=head->next;
while(p)
{
printf("%d\t", p->date );
p=p->next;
}
printf("\n\n"); struct node *head2; //存储删除某个元素后的链表
int key;
scanf("%d", &key ); //读入要删除的特定元素 head2 = Delete(head, key); //执行 链表删除函数
p=head2->next;
while(p)
{
printf("%d\t", p->date );
p=p->next;
}
printf("\n\n"); struct node *head3;
int pos;
scanf("%d %d", &pos, &key );
head3 = Insert(head2, pos, key ); p=head3->next; //输出最后状态的链表
while(p)
{
printf("%d\t", p->date );
p=p->next;
}
printf("\n"); return 0;
} */

SDUT OJ 2054 双向链表的实现 (结构体node指针+遍历 *【模板】)的更多相关文章

  1. 【学习笔记】【C语言】指向结构体的指针

    1.指向结构体的指针的定义 struct Student *p;  2.利用指针访问结构体的成员 1> (*p).成员名称 2> p->成员名称 3.代码 #include < ...

  2. c语言中较常见的由内存分配引起的错误_内存越界_内存未初始化_内存太小_结构体隐含指针

    1.指针没有指向一块合法的内存 定义了指针变量,但是没有为指针分配内存,即指针没有指向一块合法的内浅显的例子就不举了,这里举几个比较隐蔽的例子. 1.1结构体成员指针未初始化 struct stude ...

  3. C#将结构体和指针互转的方法

    . 功能及位置 将数据从托管对象封送到非托管内存块,属于.NET Framework 类库 命名空间:System.Runtime.InteropServices 程序集:mscorlib(在 msc ...

  4. C语言结构体和指针

    指针也可以指向一个结构体,定义的形式一般为: struct 结构体名 *变量名; 下面是一个定义结构体指针的实例: struct stu{ char *name; //姓名 int num; //学号 ...

  5. 37深入理解C指针之---结构体与指针

    一.结构体与指针 1.结构体的高级初始化.结构体的销毁.结构体池的应用 2.特征: 1).为了避免含有指针成员的结构体指针的初始化复杂操作,将所有初始化动作使用函数封装: 2).封装函数主要实现内存的 ...

  6. 深入了解Windows句柄到底是什么(句柄是逻辑指针,或者是指向结构体的指针,图文并茂,非常清楚)good

    总是有新入门的Windows程序员问我Windows的句柄到底是什么,我说你把它看做一种类似指针的标识就行了,但是显然这一答案不能让他们满意,然后我说去问问度娘吧,他们说不行网上的说法太多还难以理解. ...

  7. 关于C语言结构体,指针,声明的详细讲解。——Arvin

    关于结构体的详细分析 只定义结构体 struct Student { int age; char* name; char sex;//结构体成员 };//(不要忘记分号) Student是结构体的名字 ...

  8. c语言结构体&常指针和常量指针的区别

    结构体: 关系密切但数据类型不尽相同, 常指针和常量指针的区别: char * const cp : 定义一个指向字符的指针常数,即const指针,常指针. const char* p : 定义一个指 ...

  9. C#调用c++Dll 结构体数组指针的问题

    参考文章http://blog.csdn.net/jadeflute/article/details/5684687 但是这里面第一个方案我没有测试成功,第二个方案我感觉有点复杂. 然后自己写啦一个: ...

随机推荐

  1. hdu4336 Card Collector(概率DP,状态压缩)

    In your childhood, do you crazy for collecting the beautiful cards in the snacks? They said that, fo ...

  2. cf550D Regular Bridge

    Regular Bridge An undirected graph is called k-regular, if the degrees of all its vertices are equal ...

  3. ftp链接、上传、下载、断开

    开发环境:Jdk 1.8 引入第三方库:commons-net-2.2.jar(针对第一种方法) 一.基于第三方库FtpClient的FTP服务器数据传输 由于是基于第三方库,所以这里基本上没有太多要 ...

  4. centos7 下修改网络配置

    修改ip地址 编辑 /etc/sysconfig/network-scripts/ifcfg-eth0 TYPE=Ethernet BOOTPROTO=static 静态ip DEFROUTE=yes ...

  5. 星球大战 BZOJ 1015

    星球大战 [问题描述] 很久以前,在一个遥远的星系,一个黑暗的帝国靠着它的超级武器统治者整个星系.某一天,凭着一个偶然的机遇,一支反抗军摧毁了帝国的超级武器,并攻下了星系中几乎所有的星球.这些星球通过 ...

  6. NOJ 1116 哈罗哈的大披萨 【淡蓝】 [状压dp+各种优化]

    我只能说,珍爱生命,远离卡常数的题...感谢陈老师和蔡神,没有他们,,,我调一个星期都弄不出来,,,, 哈罗哈的大披萨 [淡蓝] 时间限制(普通/Java) : 1000 MS/ 3000 MS   ...

  7. 使用MYSQL命令直接导入导出SQL文件(转)

    参考:http://blog.csdn.net/jiary5201314/article/details/52026816 1.MYSQL中将数据库导出成SQL文件 其实很简单的,就是一条语句就可以了 ...

  8. hdu3078 建层次树+在线LCA算法+排序

    题意:n个点,n-1条边构成无向树,每个节点有权,Q次询问,每次或问从a->b的最短路中,权第k大的值,/或者更新节点a的权, 思路:在线LCA,先dfs生成树0,标记出层数和fa[](每个节点 ...

  9. android连数据库

    package com.rockcheck.mes; import android.os.AsyncTask; import android.support.v7.app.AppCompatActiv ...

  10. Elixir与编辑器安装

    安装 Elixir 每个操作系统的安装说明可以在 elixir-lang.org 网站上 Installing Elixir 部分找到. 安装后你可以很轻松地确认所安装的版本. ~$:elixir - ...