首页 | 新闻 | 新品 | 文库 | 方案 | 视频 | 下载 | 商城 | 开发板 | 数据中心 | 座谈新版 | 培训 | 工具 | 博客 | 论坛 | 百科 | GEC | 活动 | 主题月 | 电子展
返回列表 回复 发帖

C语言经典算法之双链表正排序

C语言经典算法之双链表正排序

#include<stdio.h>
#include<stdlib.h>
#include<malloc.h>
struct list{
  intdata;
struct list *next;
struct list *pre;
  };
typedef struct list node;
typedef node *link;
link front=NULL,rear,ptr,head=NULL;
link push(int item){
link newnode=malloc(sizeof(node));
newnode->data=item;
if(head==NULL)
{
head=newnode;
head->next=NULL;
head->pre=NULL;
rear=head;
}
else
{
rear->next=newnode;
newnode->pre=rear;
newnode->next=NULL;
rear=newnode;
}
return head;
}
void makenull(){           
front=NULL;
rear=NULL;
}
empty(){
if(front==NULL)
  return 1;
else
  return 0;
  }
int tops(){
  if(empty())
   return NULL;
  else
    return rear->data;
   }
void pop(){
  if(empty())
   printf("stack is empty!\n");
  else
   rear=rear->pre;
   }
void display(link l){
   link p;
   p=l;
   while(p!=NULL){
     printf("%d->",p->data);
     p=p->next;
    }
}
void main(){
int n,i;
printf("input your firstdata!\n");
scanf("%d",&n);
front=push(n);
  /*another data*/
for(i=0;i<3;i++)
{
printf("input:\n");
scanf("%d",&n);
push(n);
}
ptr=front;
display(ptr);
printf("\n Please enter any key to pop");
getch();
pop();
ptr=front;
display(ptr);
getch();
}
返回列表