数据结构实验一:线性表的基本操作

简介:
顺序表—线性表的顺序实现删除多余元素
#include<iostream>
#include<stdlib.h>
using  namespace std;
struct node
{
     int n[ 100];
     int length;
     int tag;
}a;
void init()
{
     int i;
     for(i= 0;i< 30;i++)
    {
        a.n[i]=rand()% 10;
        a.length++;
    }
}
void display( int n)
{
     int i;
     for(i= 0;i<n;i++)
    cout<<a.n[i]<< "   ";
    cout<<endl;
}
int find( int num)
{
     int i;
     for(i= 0;i<a.tag;i++)
     if(a.n[i]==num)
     return  1;
     return  0;
}
void del()
{
     int i;
     for(i= 0;i< 30;i++)
    {
         if(!find(a.n[i]))
        a.n[a.tag++]=a.n[i];
    }
}
int main()
{
    init();
    display( 30);
    del();
    display(a.tag);
     return  0;
}





链表——链表实现删除多余元素

#include<iostream>
#include<stdlib.h>
using  namespace std;
typedef  struct s
{
     int data;
     struct s *next;
}list;
list *head2,*tail;
void insert(list *l, int n)
{
    list *p;
    p= new list;
    p->data=n;
    p->next=l->next;
    l->next=p;
}
void display(list *l)
{
    list *p;
    p=l->next;
     while(p!=NULL)
    {
        cout<<p->data<< "   ";
        p=p->next;
    }
    cout<<endl;
}
int find( int n)
{
    list *p;
    p=head2->next;
     while(p!=NULL)
    {
         if(p->data==n)
         return  1;
        p=p->next;
    }
     return  0;
}
void del(list *l)
{
    list *p,*q;
    p=l;
     while(p->next->next!=NULL)
    {
         if(!find(p->next->data))
        {
            q=p->next;
            p->next=q->next;
            q->next=NULL;
            tail->next=q;
            tail=q;
        }
         else
        p=p->next;
    }
     if(!find(p->next->data))
    {
        q=p->next;
        q->next=NULL;
        tail->next=q;
        tail=q;
    }
}
int main()
{
     int i;
    list *head1;
    head1= new list;
    head2= new list;
    head1->next=NULL;
    head2->next=NULL;
    tail=head2;
     for(i= 1;i<= 30;i++)
    insert(head1,rand()% 10);
    display(head1);
    del(head1);
    display(head2);
}
复制代码

博主ma6174对本博客文章(除转载的)享有版权,未经许可不得用于商业用途。转载请注明出处http://www.cnblogs.com/ma6174/

对文章有啥看法或建议,可以评论或发电子邮件到ma6174@163.com


本文转自ma6174博客园博客,原文链接:http://www.cnblogs.com/ma6174/archive/2012/01/05/2313297.html ,如需转载请自行联系原作者
相关文章
|
4月前
|
存储 C语言
数据结构中的线性表链式存储介绍及其基本操作
链式存储是线性表的一种重要存储方式,它通过节点和指针的结构,实现了灵活的动态存储管理。本文介绍了单向链表的基本操作,并提供了相应的C语言代码示例。理解和掌握链表的操作对学习和应用数据结构具有重要意义。希望这篇博客能帮助你更好地理解线性表的链式存储。
88 2
|
4月前
|
算法
数据结构和算法学习记录——线性表之双向链表(上)-结点类型定义、初始化函数、创建新结点函数、尾插函数、打印函数、尾删函数
数据结构和算法学习记录——线性表之双向链表(上)-结点类型定义、初始化函数、创建新结点函数、尾插函数、打印函数、尾删函数
38 0
|
7天前
|
存储 Java
java数据结构,线性表顺序存储(数组)的实现
文章介绍了Java中线性表顺序存储(数组)的实现。线性表是数据结构的一种,它使用数组来实现。文章详细描述了线性表的基本操作,如增加、查找、删除、修改元素,以及其他操作如遍历、清空、求长度等。同时,提供了完整的Java代码实现,包括MyList接口和MyLinearList实现类。通过main函数的测试代码,展示了如何使用这些方法操作线性表。
|
5月前
|
存储
数据结构第二课 -----线性表之单向链表
数据结构第二课 -----线性表之单向链表
|
4月前
|
存储 测试技术
【数据结构】操作受限的线性表,栈的具体实现
【数据结构】操作受限的线性表,栈的具体实现
52 5
|
4月前
|
存储 测试技术
【数据结构】操作受限的线性表,队列的具体实现
【数据结构】操作受限的线性表,队列的具体实现
37 4
|
5月前
题目----数据结构线性表----字符串逆序
题目----数据结构线性表----字符串逆序
30 1
|
4月前
|
存储 算法
数据结构和算法学习记录——特殊线性表之队列-队列的概念、队列结构体类型定义 、基本接口函数、初始化函数、销毁队列函数、入队列函数、判断队列是否为空、出队列函数、读取队头队尾的数据 、计算队列数据个数
数据结构和算法学习记录——特殊线性表之队列-队列的概念、队列结构体类型定义 、基本接口函数、初始化函数、销毁队列函数、入队列函数、判断队列是否为空、出队列函数、读取队头队尾的数据 、计算队列数据个数
29 0
|
4月前
|
算法 C语言
数据结构和算法学习记录——特殊线性表之栈(下)-销毁栈函数、判断栈是否为空、压栈函数、出栈函数、取栈顶元素、计算栈中有多少个元素、栈有关习题-有效的括号
数据结构和算法学习记录——特殊线性表之栈(下)-销毁栈函数、判断栈是否为空、压栈函数、出栈函数、取栈顶元素、计算栈中有多少个元素、栈有关习题-有效的括号
30 0
|
4月前
|
算法
数据结构和算法学习记录——特殊线性表之栈(上)-栈的概念、栈的结构、链式栈数组栈、栈的结构体定义、栈的基本接口函数、栈顶初始化函数
数据结构和算法学习记录——特殊线性表之栈(上)-栈的概念、栈的结构、链式栈数组栈、栈的结构体定义、栈的基本接口函数、栈顶初始化函数
26 0