当前位置: 首页 > news >正文

学计算机好还是大数据seo网站推广杭州

学计算机好还是大数据,seo网站推广杭州,网址大全2345仙踪林,做微商加入什么移动电商网站单链表简介 单链表结构 头指针是指向链表中第一个结点的指针 首元结点是指链表中存储第一个数据元素a1的结点 头结点是在链表的首元结点之前附设的一个结点;数据域内只放空表标志和表长等信息 单链表存储结构定义: typedef struct Lnode { ElemTyp…

单链表简介

单链表结构

头指针是指向链表中第一个结点的指针

首元结点是指链表中存储第一个数据元素a1的结点

头结点是在链表的首元结点之前附设的一个结点;数据域内只放空表标志和表长等信息

 单链表存储结构定义:

typedef struct Lnode

{

     ElemType   data;       //数据域

     struct LNode  *next;   //指针域

}LNode,*LinkList;  

// *LinkListLnode类型的指针

单链表基本操作

#include <stdlib.h>
#include <stdio.h>#define  OK        1
#define  FALSE     0
#define  ERROR    -1
#define  OVERFLOW -2typedef  int Status;
typedef  int ElemType;typedef struct LNode                 //链表结点定义
{ElemType Data;                   //结点的数据域struct LNode *Next;              //结点的指针域
}LNode, *LinkList;//功能:初始化单链表,即生成只有表头的单链表,成功返回OK,否则返回ERROR
Status InitLinkList_L(LinkList &L)
{L = (LinkList)malloc(sizeof(LNode));            //生成头结点if(L){L->Next = NULL;                             //头结点的next指针为空return OK;}elsereturn ERROR;
}//功能:向单链表中输入n个数据,成功返回OK,否则返回ERROR
Status InputData_L(LinkList &L, int n)
{int      i;LinkList p;printf("链表建立方法:头插法!\n");for(i = 1; i <= n; i++){printf("第 %d 个数据:", i);p = (LinkList)malloc(sizeof(LNode));        //生成新的数据结点if(p){scanf("%d", &(p->Data));p->Next = L->Next;                      //插入位置为头结点后面,因此p的指针为头结点指针L->Next = p;                            //头结点指针指向新的数据结点}elsereturn ERROR;}return OK;
}//功能:查询链表L的第i个位置上是否存在元素,存在返回OK,否则返回ERROR,找到的数据存放到变量e中
Status GetElem_L(LinkList L, int i, ElemType &e)
{LinkList p;int j;p = L->Next;  j = 1;while(p&&(j<i)){p = p->Next;j++;}if(!p || j > i)return ERROR;e = p->Data;return OK;
}//功能:向链表L的第i个位置插入一个数据e,插入成功返回OK,否则返回ERROR
Status ListInsert_L(LinkList &L, int i, ElemType e)
{LinkList p, s;int j;p = L;j = 0;while(p &&(j < i - 1)){p = p->Next;j++;}if(!p || j > i)return ERROR;s = (LinkList)malloc(sizeof(LNode));s->Data = e;s->Next = p->Next;p->Next = s;return OK;
}//功能:将链表L的第i个位置删除,删除的值保存到e,删除成功返回OK,否则返回ERROR
Status ListDelete_L(LinkList &L, int i, ElemType &e)
{LinkList p, q;int j;p = L;   	j = 0;while(p->Next && (j < i-1)){p = p->Next;j++;}if(!(p->Next) || (j > i - 1))return ERROR;q = p->Next;p->Next = q->Next;e = q->Data;  free(q);                        //删除后,释放对应数据的空间return OK;
}//功能:求链表L的长度,返回链表L的长度
int ListLength_L(LinkList L)
{int j = 0;LinkList p = L;while(p->Next){p = p->Next;j++;}return j;
}//功能:依次输出链表L的每个数据
void OutputList_L(LinkList L)
{LinkList p;int j = 0;                                  //计数器p = L->Next;while(p){j++;printf("第 %d 个数据为:", j);printf("%d\n", p->Data);p = p->Next;}if(j == 0)printf("\n空链表,数据总个数为 0 .\n");elseprintf("\n链表数据总数为:%d\n", j);
}//功能:依次清除链表L的每个数据,并释放相应的空间,清除成功,返回OK,否则ERROR
Status ClearLis_L(LinkList &L)
{LinkList p,	q;p = L->Next; if(!p){printf("链表为空,无需清除!\n");return OK;}printf("正在清除链表L中的数据,请等待...\n");while(p)              //链表非空{q = p;            //p = q->Next;free(q);}L->Next = NULL;printf("链表L中的数据清除完成!\n");return OK;
}void ShowMenu()           //主菜单
{  printf("\n");printf("\n****************单链表(头插法)数据操作****************\n\n");printf("\t\t1  链表数据输出\n\n");printf("\t\t2  链表数据插入\n\n");printf("\t\t3  链表数据删除\n\n");printf("\t\t4  链表数据查询\n\n");printf("\t\t5  链表数据清空\n\n");printf("\t\t0  退出系统\n\n");printf("****************单链表(头插法)数据操作****************\n");printf("\n");
}//功能:菜单2的操作处理,实现:在单链表的第i个位置插入数据e的操作
void SubMenu2(LinkList &L)
{int      i;ElemType e;printf("插入位置:");scanf("%d", &i);printf("插入的数据:");scanf("%d", &e);if(ListInsert_L(L, i, e) == OK)printf("在单链表L的第 %d 位置成功插入数据 %d .\n", i, e);elseprintf("插入位置:%d 错误!\n", i);
}//功能:菜单3的操作处理,实现:在单链表的第i个位置删除数据e的操作
void SubMenu3(LinkList &L)
{//ListDelete_Lint      i;ElemType e;printf("删除位置:");scanf("%d", &i);if(ListDelete_L(L, i, e) == OK)printf("在单链表L的第 %d 位置成功删除数据 %d .\n", i, e);elseprintf("删除位置:%d 错误!\n", i);
}//菜单3的操作处理,实现:查询单链表的第i个位置数据的操作
void SubMenu4(LinkList L)
{int      i;ElemType e;printf("插入位置:");scanf("%d", &i);if(GetElem_L(L, i, e) == OK)printf("单链表L的第 %d 个位置的数据:%d\n", i, e);elseprintf("单链表L的第 %d 个位置的数据不存在!\n", i);
}void main()
{int choice = 0;                //用户功能选择LinkList L;InitLinkList_L(L);             //初始化单链表while(1){system("CLS");ShowMenu();printf("Please choose(请选择): ");scanf("%d",&choice);switch(choice){case 1:{OutputList_L(L);                          //调用输出函数对链表的数据进行输出fflush(stdin);system("pause");break;}case 2:{SubMenu2(L);                             //调用菜单2功能,实现数据的插入操作fflush(stdin);system("pause");break;}case 3:{SubMenu3(L);fflush(stdin);system("pause");break;}case 4:{SubMenu4(L);getchar(); getchar(); system("CLS");break;}case 5:{ClearLis_L(L);fflush(stdin);system("pause");break;}case 0:{system("CLS");printf("谢谢使用!\n");exit(0);}default:{printf("功能选择错误,只能选择0-5!\n");fflush(stdin);system("pause");}}}
}

单链表创建(尾插法)

#include <stdio.h>
#include <stdlib.h>#define  OK        1
#define  FALSE     0
#define  ERROR    -1
#define  OVERFLOW -2typedef int ElemType;//单链表结点结构定义
typedef struct LNode
{           ElemType        data;   //每个结点实际存放的数据—数据域struct LNode   *next;   //下一个结点的地址—指针域
}LNode, *LinkList;int CreateList(LinkList &L, int n)
{int i;LinkList tail, p;L = (LinkList) malloc (sizeof (LNode));if(!L)return ERROR;L->next = NULL;tail = NULL;for(i = 1; i <= n; i++){p = (LinkList) malloc (sizeof (LNode));if(!p)return ERROR;printf("\n\n第%d个数据为:", i);scanf("%d", &p->data);    // 输入元素值p->next = NULL;if(i == 1)L->next = p;elsetail->next = p;tail = p;}return OK;
}void TransverList(LinkList L)
{LinkList p;int j;p = L->next;   	j = 0;while(p){j++;printf("第%d个数据为:", j);printf("%d\n\n", p->data);p = p->next;}
}void main()
{LinkList L;int n;printf(" *******************************************************************\n\n");printf("                         创建链表——尾插法\n\n");printf(" *******************************************************************\n\n");printf("数据个数:");scanf("%d", &n);CreateList(L, n);printf("\n\n链表中的数据浏览结果\n\n");TransverList(L);
}

静态链表

#include <stdio.h>
#include <stdlib.h>#define  OK        1
#define  FALSE     0
#define  ERROR    -1
#define  OVERFLOW -2
#define  MAXSIZE   10          // 静态链表的最大长typedef  int Status;
typedef  int ElemType;struct Component              //静态链表的结点结构定义
{ElemType   data;int        cur;           //相对地址,相对于0号位置的地址,实际上就是数组的下标
};//功能:实现静态链表的初始化操作,初始化成功,返回OK
Status InitStaticList(Component VList[ MAXSIZE + 1])
{int i;VList[0].cur = -1;                    //置该静态链表为空链表for(i = 1; i <= MAXSIZE; i++)         //置该静态链表的每个空间都可以存放数据VList[i].cur = 0;                 //每个空间的cur为0表示该空间可以存放数据,否则表示该空间已经存放数据return OK;
}//功能:实现静态链表数据的全部输出
void OutputStaticList( Component VList[MAXSIZE + 1])
{int i = 0, k = 1;if( VList[0].cur == -1)printf("\n 静态链表为空,无数据!\n");else{printf("\n静态链表中的数据为:");i = 0;while( VList[i].cur != -1){printf("第 %d 数据为:%d\n", k, VList[VList[i].cur].data);i = VList[i].cur; k++;}}
}//功能:实现静态链表数据的插入,插入数据是在尾部插入(也可实现在第i个位置插入数据),成功返回1,否则,返回0
Status InsertStaticList(Component VList[MAXSIZE + 1], ElemType e)
{int i = 0, pos = 0;if(VList[0].cur == -1)                     //空表时,插入数据的位置为1号位置pos = 1;else                                       //非空表,插入的位置不清楚,因此需检索哪个空闲,就写入到该空间{for(i = 1; i <= MAXSIZE; i++)          //寻找第一个可插入位置if( VList[i].cur == 0)break;if( i >= MAXSIZE)                      //空间全部全部使用,则无插入位置return ERROR;    elsepos = i;                           //将插入位置赋给pos}if(VList[0].cur == -1)                     //空表时,插入数据的位置为1号位置i = 0;else{for(i = 1; i <= MAXSIZE; i++)            //寻找链表的最后一个数据位置if( VList[i].cur == -1)break;if( i>= MAXSIZE)return ERROR;}if( pos == 0)return 0;else{VList[pos].data  = e;VList[i].cur = pos;VList[pos].cur = -1;return OK;}
}//功能:实现静态链表数据的删除,删除成功,则返回该数据在静态链表中的位置,否则返回0
int DeleteStaticList(Component VList[MAXSIZE + 1], ElemType e)
{int i = 0, k = 1;if(VList[i].cur == -1)                     //空的静态表,不能删除数据return 0;while(VList[VList[i].cur].data != e)i = VList[i].cur;if( i == -1)                               //没找到return 0;else                                       //找到,i存储的是被删除元素的前驱{k = VList[i].cur;VList[i].cur = VList[k].cur;VList[k].cur = 0;                      //该位置空出,可以写入新的数据}return OK;
}//功  能:实现静态链表数据的查询,成功返回该数据在链表中的位置,否则,返回0
int SearchStaticList(Component VList[MAXSIZE + 1], ElemType e)
{int i = 0;if(VList[0].cur = -1)return 0;i = 1;while(VList[i].cur != -1)                 //注意:不能按数组的方式从上到下扫描,不然可能找到以前的数据。必须按链表的方式进行扫描if(VList[i].data != e)i = VList[i].cur;if( i == -1)                               //没找到return 0;elsereturn i;                              //找到返回其所在的下标
}void ShowMenu() //主菜单
{  printf("\n");printf("\n****************静态链表基本操作****************\n\n");printf("\t\t1  静态链表初始化\n\n");printf("\t\t2  静态链表数据显示\n\n");printf("\t\t3  静态链表数据插入\n\n");printf("\t\t4  静态链表数据删除\n\n");printf("\t\t5  静态链表数据查询\n\n");printf("\t\t0  退 出(exit)\n\n");printf("****************静态链表基本操作****************\n");printf("\n");
}void main()
{int      choice = 0;               //功能选项ElemType e;Component VList[MAXSIZE + 1];InitStaticList(VList);             //初始化while(1){system("CLS");ShowMenu();printf("Please choose: ");scanf("%d",&choice);switch(choice){case 1:{printf("严重警告:重新初始化静态链表,会使原有数据丢失!\n");if (InitStaticList(VList) == 1)printf("\n静态链表初始化成功!\n\n");fflush(stdin);system("pause");break;}case 2:{OutputStaticList(VList);fflush(stdin);system("pause");break;}case 3:{printf("插入数据:");scanf("%d", &e);InsertStaticList(VList, e);fflush(stdin);system("pause");break;}case 4:{printf("删除数据:");scanf("%d", &e);DeleteStaticList(VList, e);fflush(stdin);system("pause");break;}case 5:{printf("查询数据:");scanf("%d", &e);InsertStaticList(VList, e);fflush(stdin);system("pause");break;}case 0:{system("CLS");printf("Thanks for using!\n");exit(0);}default:{printf("功能选择错误,只能选择0-5!\n");fflush(stdin);system("pause");}}}
}

http://www.dinnco.com/news/28730.html

相关文章:

  • wordpress七牛插件亚马逊关键词优化软件
  • 兰州网站建设q.479185700惠小程序怎么开发自己的小程序
  • 云南旅行社网站建设b2b免费网站推广平台
  • wordpress 编辑器标签全网优化推广
  • 提供专业网站建设怎么找平台推广自己的产品
  • 做网站需要考虑seo吗免费网络推广的方法
  • 无锡定制网站建设品牌宣传策划方案
  • 织梦仿站社区推广
  • 传统pc网站免费的行情网站
  • 程序员常用的工具有哪些深圳优化公司找高粱seo服务
  • ppt模板怎么做 下载网站防止恶意点击软件管用吗
  • 网站改版公司指数型基金怎么买
  • 全国公安网站备案网站空间租用
  • 漳州正规网站建设费用网络推广宣传方式
  • 做保洁网站找谁做必应搜索引擎怎么样
  • 开平建设局网站深圳关键词推广优化
  • 外贸网站什么采集软文营销成功案例
  • 凡科网站怎么做百度经验官网入口
  • 防水网站怎么做百度搜索指数1000是什么
  • 贵阳网站制作搜索引擎的作用
  • 网站备案 他人身份证汕头seo网站建设
  • 网站空间后台登录产品运营方案
  • 做网站文字居中代码软件制作平台
  • 做网站推广有啥活动什么是淘宝搜索关键词
  • 新手建站教程视频网络营销策略的特点
  • 怎么增加网站访问量营销网站定制
  • 雅思真题有网站做吗一键生成网页
  • 产品设计的8个方法网站seo提升
  • 自己做的网站怎么嵌入高德地图优化落实防控措施
  • 做网站用是内网穿透好关于进一步优化落实疫情防控措施