链表的基本操作

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#define mem(x,y) memset(x,y,sizeof(x))
using namespace std;
typedef long long LL;
struct Node{
	int date;
	struct Node *next;
};
Node *Creatlist(Node *head,int n){
	head->next=NULL;
	for(int i=0;i<n;i++){
		Node *p;
		p=(Node*)malloc(sizeof(Node));
		scanf("%d",&p->date);
		p->next=head->next;
		head->next=p;
	}
	return head;
} 
Node *Insertlist(Node *head,int pos,int val){
	Node *p,*q;
	p=head;
	for(int i=1;i<pos;i++){
		p=p->next;
	}
	q=(Node *)malloc(sizeof(Node));
	q->date=val;
	q->next=p->next;
	p->next=q;
	return head;
}
Node *Dellist(Node *head,int pos){
	Node *p,*pl;
	p=head;
	for(int i=1;i<pos;i++)p=p->next;
	pl=p->next;
	p->next=pl->next;
	free(pl);
	return head;
}
void Display(Node *head){
	Node *p;
	p=head->next;
	while(p!=NULL){
		printf("%d ",p->date);
		p=p->next;
	}
	puts("");
}
int main(){
	int n;
	Node *head;
	while(~scanf("%d",&n)){
		head=(Node*)malloc(sizeof(head));
		head->next=NULL;
		head=Creatlist(head,n);
		Display(head);
		int pos,val;
		puts("添加元素");
		scanf("%d%d",&pos,&val);
		head=Insertlist(head,pos,val);
		Display(head);
		puts("删除元素");
		scanf("%d",&pos);
		head=Dellist(head,pos);
		Display(head);
	}
	return 0;
}

  

posted @ 2015-11-18 21:03  handsomecui  阅读(258)  评论(0编辑  收藏  举报