鱼C论坛

 找回密码
 立即注册
查看: 2194|回复: 0

线性表求助

[复制链接]
发表于 2012-2-23 14:59:22 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
  1. //头文件是
  2. #ifndef Seqlist_H
  3. #define Seqlist_H

  4. const int MaxSize=100;

  5. template <class T>
  6. class Seqlist
  7. {
  8. public:
  9.     Seqlist()
  10.     {
  11.         length=0;
  12.     }
  13.     Seqlist(T a[ ],int n);
  14.     void Insert(int i,T x);//在线性表的第i个位置插入x
  15.     T Delete(int i);//删除线性表的第i个元素
  16.     int Locate(T x);//按值查找,求线性表中值为x的元素序号
  17.     void PrintList();
  18. private:
  19.     T data[MaxSize];//存放数据元素的数组
  20.     int length;

  21. };
  22. #endif
复制代码
  1. #include <iostream>
  2. #include <Seqlist.h>
  3. using std::cout;
  4. using std::cin;
  5. using std::endl;

  6. template <class T>
  7. Seqlist<T>::Seqlist(T a[],int n)
  8. {
  9.     if(n>MaxSize)
  10.     {
  11.         cout<<"参数非法\n";
  12.     }
  13.     for(int i=0;i<n;i++)
  14.     {
  15.         data[i]=a[i];
  16.     }
  17.     length=n;
  18. }

  19. template <class T>
  20. void Seqlist<T>::Insert(int i,T x)
  21. {
  22.     if(length>=MaxSize)
  23.     {
  24.         throw "上溢";
  25.     }
  26.     if(i<1||i>length+1)
  27.     {
  28.         throw "位置";
  29.     }
  30.     for(int j=length;j>=i;j--)
  31.     {
  32.         data[j]=data[j-1];
  33.     }
  34.     data[i-1]=x;
  35.     length++;
  36. }
  37. template <class T>
  38. T Seqlist<T>::Delete(int i)
  39. {
  40.     if(length==0)
  41.     {
  42.         throw "下溢";
  43.     }
  44.     if(i<1||i>length+1)
  45.     {
  46.         throw "位置";
  47.     }
  48.     T x=data[i-1];
  49.     for(int j=i;j<length;j++)
  50.     {
  51.         data[j-1]=data[j];
  52.     }
  53.     length--;
  54.     return x;
  55. }

  56. template <class T>
  57. int Seqlist<T>::Locate(T x)
  58. {
  59.     int a[50];
  60.     for(int i=0;i<length;i++)
  61.     {
  62.         if(data[i]==x)
  63.         {
  64.             return i+1;
  65.         }
  66.     }
  67.     return 0;
  68. }

  69. template <class T>
  70. void Seqlist<T>::PrintList()
  71. {
  72.     for(int i=0;i<length;i++)
  73.     {
  74.         cout<<data[i]<<endl;
  75.     }
  76. }


  77. int main()
  78. {
  79.     int r[ ]={1,2,3,4,5};
  80.     Seqlist<int> a(r,5);
  81.     cout<<"插入前的数据为:"<<endl;
  82.     a.PrintList();
  83.     cout<<"值为3的元素为:  ";
  84.     cout<<a.Locate(3)<<endl;
  85.     try
  86.     {
  87.         a.Insert(2,3);
  88.     }
  89.     catch(char *s)
  90.     {
  91.         cout<<s<<endl;
  92.     }
  93.     cout<<"执行插入操作后的数据为:"<<endl;
  94.     a.PrintList();
  95.     cout<<"值为3的元素为:  ";
  96.     cout<<a.Locate(3)<<endl;
  97.     cout<<"当前数据为:"<<endl;
  98.     a.PrintList();
  99.     try
  100.     {
  101.         a.Delete(1);
  102.     }
  103.     catch(char *s)
  104.     {
  105.         cout<<s<<endl;
  106.     }
  107.     cout<<"删除后的数据为:"<<endl;
  108.     a.PrintList();

  109.     return 0;
  110. }
复制代码
程序有点问题,就是当定位(locate())的时候,如果有多个相等的数据,只能定位到第一个相等的数据,有人知道应该怎么修改吗?只要把Locate()这个函数改下,其他没问题。。。。
小甲鱼最新课程 -> https://ilovefishc.com
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-11-11 13:56

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表