zoukankan      html  css  js  c++  java
  • 单链表的增、删、改、减(C++)

    首先是是一个简单的例子,单链表的建立和输出。

    程序1.1

    #include<iostream>
    #include<string>
    using namespace std;
    struct Student{
    	string name;
    	string score;
    	Student *next;//定义了指向Candidate类型变量的指针
    };
    int main(){
    	int n;//
    	cout<<"请输入学生的总数:";
    	cin>>n;
    	int i=1;
    	Student *p=NULL;
    	Student *node=NULL;
    	Student *head=NULL;
    	//建立链表
    	for(;i<=n;i++){
    		node=new Student;
    		cout<<"请输入第"<<i<<"个同学的姓名:";
    		cin>>node->name;
    		cout<<"请输入第"<<i<<"个同学的成绩:";
    		cin>>node->score;
    		if(head==NULL)
    			head=node;
    		else
    			p->next=node;
    		p=node;
    		if(i==n){
    			p->next=NULL;
    		}
    	}
    	//输出链表
    	p=head;
    	cout<<"链表已经建立!"<<endl;
    	cout<<"
    ==========下面输入刚才的数据=============
    "<<endl;
    	i=1;
    	while(p!=NULL){
    		cout<<"第"<<i<<"个同学==="<<p->name<<"==成绩===="<<p->score<<endl;
    		p=p->next;
    		i++;
    	}
    	//销毁链表
    	Student *d;
    	p=head;
    	while(p!=NULL){
    		d=p;
    		p=p->next;
    		delete d;
    	}
    	return 0;
    }


    在程序1.1中,我们已经建立了一个链表。然后,我们在小樱和鸣人之间插入一个佐井同学的成绩

    #include<iostream>
    #include<string>
    using namespace std;
    struct Student{
    	string name;
    	string score;
    	Student *next;//定义了指向Candidate类型变量的指针
    };
    Student * Create(Student * head){
    	Student *p=NULL;
    	Student *node=NULL;
    	int n;//
    	cout<<"请输入学生的总数:";
    	cin>>n;
    	for(int i=1;i<=n;i++){
    		node=new Student;
    		cout<<"请输入第"<<i<<"个同学的姓名:";
    		cin>>node->name;
    		cout<<"请输入第"<<i<<"个同学的成绩:";
    		cin>>node->score;
    		if(head==NULL)
    			head=node;
    		else
    			p->next=node;
    		p=node;
    		if(i==n){
    			p->next=NULL;
    		}
    	}
    	return head;
    }
    void Print(Student * head){
    	Student *p=NULL;
    	p=head;
    	cout<<"链表已经建立!"<<endl;
    	cout<<"
    ==========下面输入刚才的数据=============
    "<<endl;
    	int i=1;
    	while(p!=NULL){
    		cout<<"第"<<i<<"个同学==="<<p->name<<"==成绩===="<<p->score<<endl;
    		p=p->next;
    		i++;
    	}
    	cout<<"
    "<<endl;
    }
    void Insert(Student * head,int k){
    	Student *p=NULL;
    	Student *node=NULL;
    	p=head;
    	int i=1;
    	while(p!=NULL){
    		if(i+1==k){
    			node=new Student;
    			cout<<"第"<<k<<"位同学的名字:";
    			cin>>node->name;
    			cout<<"第"<<k<<"位同学的成绩:";
    			cin>>node->score;
    			node->next=p->next;
    			p->next=node;
    		}
    		p=p->next;
    		i++;
    	}
    }
    	
    void Destory(Student * head){
        Student *d;
    	Student *p=NULL;
    	p=head;
    	while(p!=NULL){
    		d=p;
    		p=p->next;
    		delete d;
    	}
    }
    int main(){
    	Student *head=NULL;
    	//创建链表
    	head=Create(head);
    	//输出链表
    	Print(head);
    	//插入数据
    	int k;
    	cout<<"请输入你要插入的同学的序号:";
    	cin>>k;
    	Insert(head,k);
    	//输出链表
    	Print(head);
    	//销毁链表
        Destory(head);
    	return 0;
    }


    现在,佐井同学的成绩已经插入。

    但是,卡卡西老师发现,鸣人的成绩抄错了,实际上是100,需要修改成绩;然后,佐助同学辍学了,所以,还要删除他的成绩。

    #include<iostream>
    #include<string>
    using namespace std;
    struct Student{
    	string name;
    	string score;
    	Student *next;//定义了指向Candidate类型变量的指针
    };
    Student * Create(Student * head){
    	Student *p=NULL;
    	Student *node=NULL;
    	int n;//
    	cout<<"请输入学生的总数:";
    	cin>>n;
    	for(int i=1;i<=n;i++){
    		node=new Student;
    		cout<<"请输入第"<<i<<"个同学的姓名:";
    		cin>>node->name;
    		cout<<"请输入第"<<i<<"个同学的成绩:";
    		cin>>node->score;
    		if(head==NULL)
    			head=node;
    		else
    			p->next=node;
    		p=node;
    		if(i==n){
    			p->next=NULL;
    		}
    	}
    	return head;
    }
    void Print(Student * head){
    	Student *p=NULL;
    	p=head;
    	cout<<"链表已经建立!"<<endl;
    	cout<<"
    ==========下面输入刚才的数据=============
    "<<endl;
    	int i=1;
    	while(p!=NULL){
    		cout<<"第"<<i<<"个同学==="<<p->name<<"==成绩===="<<p->score<<endl;
    		p=p->next;
    		i++;
    	}
    	cout<<"
    "<<endl;
    }
    void Insert(Student * head,int k){
    	Student *p=NULL;
    	Student *node=NULL;
    	p=head;
    	if(k==1){
    			node=new Student;
    			cout<<"第1位同学的名字:";
    			cin>>node->name;
    			cout<<"第1位同学的成绩:";
    			cin>>node->score;
    			node->next=head->next;
    			head=node;
    	}
    	int i=1;
    	while(p!=NULL){
    		if(i+1==k){
    			node=new Student;
    			cout<<"第"<<k<<"位同学的名字:";
    			cin>>node->name;
    			cout<<"第"<<k<<"位同学的成绩:";
    			cin>>node->score;
    			node->next=p->next;
    			p->next=node;
    		}
    		p=p->next;
    		i++;
    	}
    }
    	
    void Destory(Student * head){
        Student *d;
    	Student *p=NULL;
    	p=head;
    	while(p!=NULL){
    		d=p;
    		p=p->next;
    		delete d;
    	}
    }
    void Alter(Student * head,int k){
    	int i=1;
    	Student *p=head;
    	while(p!=NULL){
    		if(i==k){
    			cout<<"第"<<k<<"位同学的名字:";
    			cin>>p->name;
    			cout<<"第"<<k<<"位同学的成绩:";
    			cin>>p->score;
    		}
    		p=p->next;
    		i++;
    	}
    }
    Student * Delete(Student * head,int k){
    	int i=1;
    	Student *p=head;
    	Student *d=head;
    	if(k==1){
    		head=head->next;
    	}else{
    		while(p!=NULL){
    			if(i+1==k){
    				p->next=p->next->next;
    			}
    			p=p->next;
    			i++;
    		}
    	}
    	return head;
    }
    int main(){
    	Student *head=NULL;
    	//创建链表
    	head=Create(head);
    	//输出链表
    	Print(head);
    	//插入数据
    	int k;
    	cout<<"请输入你要插入的同学的序号:";
    	cin>>k;
    	Insert(head,k);
    	//输出链表
    	Print(head);
    	//修改链表
    	cout<<"请输入你要修改的同学的序号:";
    	cin>>k;
    	Alter(head,k);
    	//输出链表
    	Print(head);
    	//删除其中的一个项
    	cout<<"请输入你要删除的同学的序号:";
    	cin>>k;
    	head=Delete(head,k);	
    	//输出链表
    	Print(head);
    	//销毁链表
        Destory(head);
    	return 0;
    }



  • 相关阅读:
    综述:设计模式的分类及六大原则
    模板方法模式
    工厂模式三部曲之抽象工厂模式
    AI,DM,ML,PR的区别与联系
    delphi ADOCONNECTION异常拦截
    Delphi 10.2.3 精简版自动激活Embarcadero Delphi 10.2.3 v25.0.29899.2631 Lite v14.4
    Delphi使用TADOQuery的RowsAffected属性时需要注意的一个点
    delphi 新版内存表 FDMemTable
    delphi 中Adoquery ,在打开时能否让记录指针不移动? [问题点数:40分,结帖人microd]
    delphi循环校验数据集
  • 原文地址:https://www.cnblogs.com/james1207/p/3253699.html
Copyright © 2011-2022 走看看