《数据结构》实验二: 线性表实验

《数据结构》实验二:     线性表实验

一..实验目的

     巩固线性表的数据结构,学会线性表的应用。

1.回顾线性表的逻辑结构,线性表的物理存储结构和常见操作。

2.学习运用线性表的知识来解决实际问题。

3.进一步巩固程序调试方法。

4.进一步巩固模板程序设计。

二..实验内容

1.建立一个N个学生成绩的顺序表,对表进行插入、删除、查找等操作。分别输出结果。

要求如下:

1)用顺序表来实现。

#include
const int Maxsize=30;
class SeqList
{
public:
SeqList(){length=0;}
SeqList(int a[],int n);
~SeqList(){}
void Insert(int i,int x);
int Delete(int i);
int Get(int i);
int Locate(int x);
void Printlist();
private:
int data[Maxsize];
int length;
};
SeqList::SeqList(int a[],int n)
{
if(n>Maxsize)throw"参数非法";
for(int i=0;idata[i]=a[i];
length=n;
}
void SeqList::Insert(int i,int x)
{
if(length>=Maxsize)throw"上溢";
if(i<1||i>length+1)throw"位置非法";
for(int j=length;j>=i;j--)
data[j]=data[j-1];
data[i-1]=x;
length++;
}
int SeqList::Delete(int i)
{
if(length==0)throw"下溢";
if(i<1||i>length)throw"位置非法";
int x=data[i-1];
for(int j=i;jdata[j-1]=data[j];
length--;
return x;
}
int SeqList::Locate(int x)
{
for(int i=0;iif(data[i]==x)return i+1;
return 0;
}
int SeqList:: Get(int i)  
{  
  if (i < 1 && i > length) throw "查找位置非法";  
  else return data[i - 1];  
}  
void SeqList::Printlist()
{
for (int i = 0; i < length; i++)
cout << data[i]<<" ";
cout< }
void main()
{
int Score[10]={81,84,95,64,75,85,97,92,80,76};
SeqList ScoreList(Score,10);
cout<<"执行插入操作前数据为:"<ScoreList.Printlist();
try
{
ScoreList.Insert(5,88);
}
catch(char *s)
{
cout<}
cout<<"执行插入操作后数据为:"<ScoreList.Printlist();
cout<<"值为97的元素位置为:";
cout<cout<<"执行删除第一个元素操作,删除前数据为:"<ScoreList.Printlist();
try
{
ScoreList.Delete(1);
}
catch(char *s)
{
cout<}
cout<<"删除后的数据为:"<ScoreList.Printlist();
}


《数据结构》实验二: 线性表实验_第1张图片
2)用单链表来实现。

#include
using namespace std;
template  
struct Node  
{  
      DataType data;  
      Node *next;    
};   
template  
class LinkList  
{  
public:  
    LinkList( );                        
    LinkList(DataType a[ ], int n);     
    ~LinkList( );                       
    int Locate(DataType x);             
    void Insert(int i, DataType x);     
    DataType Delete(int i);             
    void PrintList( );                  
private:  
    Node *first;              
};  
template  
LinkList :: LinkList( )  
{  
    first = new Node;             
    first->next = NULL;                     
}  
template    
LinkList :: LinkList(DataType a[ ], int n)  
{  
    Node *r, *s;  
    first = new Node;    
    r = first;                   
    for (int i = 0; i < n; i++)  
    {   
        s = new Node;
s->data = a[i];       
        r->next = s; r = s;     
    }  
    r->next = NULL;        
}  
  
template  
LinkList :: ~LinkList( )  
{  
    Node *q=NULL;  
    while (first != NULL)        
    {  
        q = first;               
        first = first->next;     
        delete q;      
    }  
}  
template    
void LinkList :: Insert(int i, DataType x)  
{  
    Node *p = first, *s=NULL;  
    int count = 0;                 
    while (p != NULL && count < i - 1) 
    {  
        p = p->next;                   
        count++;  
    }  
    if (p == NULL) throw "位置";      
    else {  
        s = new Node;  s->data = x;       
        s->next = p->next; p->next = s;    
    }  
}  
  
template    
DataType LinkList :: Delete(int i)  
{  
    Node *p=first, *q=NULL;  
    DataType x;  
    int count = 0;   
    p = first;                
    while (p != NULL && count < i - 1)  
    {  
        p = p->next;  
        count++;  
    }  
    if (p == NULL || p->next == NULL) 
        throw "位置";   
    else 
{  
        q = p->next; x = q->data;       
        p->next = q->next;              
        delete q;   
        return x;  
    }  
}  
template    
int LinkList :: Locate(DataType x)   
{  
    Node *p = first->next;  
    int count = 1;         
    while (p != NULL)      
    {  
        if (p->data == x) return count;      
        p = p->next;                     
        count++;  
    }  
    return 0;                       
}  
  
template  
void LinkList :: PrintList( )  
{  
    Node *p = first->next;                 
    while (p != NULL)  
    {  
        cout << p->data<<"  ";  
        p = p->next;                 
    }  
    cout< }  
void main( )  
{  
  int Score[10]={88,85,78,76,90,81,97,75,80,69};  
  LinkList ScoreList(Score, 10);        
  cout<<"执行插入操作前数据为:"<   ScoreList.PrintList( );                  
  try  
  {  
  ScoreList.Insert(2, 85);  
  }  
  catch (char *s)  
  {  
    cout<   }  
  cout<<"执行插入操作后数据为:"<   ScoreList.PrintList( );                  
  cout<<"值为76的元素位置为:";  
  cout<   cout<<"执行删除操作前数据为:"<   ScoreList.PrintList( );                  
  try  
  {  
    ScoreList.Delete(3);                   
  }  
  catch (char *s)  
  {  
    cout<   }  
  cout<<"执行删除操作后数据为:"<   ScoreList.PrintList( );   
}

《数据结构》实验二: 线性表实验_第2张图片








                    






你可能感兴趣的:(数据结构)