zoukankan      html  css  js  c++  java
  • 顺序表

    顺序表(传递地址)

    建表、输入、输出

    typedef int Typedef;
    const int MAXSIZE = 800;
    
    typedef struct
    {
        Typedef data[MAXSIZE];
        Typedef last;
    }SeqList;
    
    SeqList *init_SeqList()
    {
        SeqList *L;
        L = (SeqList*)malloc(sizeof(SeqList)); // L= new SeqList;
        L->last = -1;
        return L;
    }
    
    void input(SeqList *L)
    {
        L->last++;
        while( cin >> L->data[L->last] )//读到文件结束符EOF 
            L->last++;
        L->last--; 
    }
    
    void print(SeqList *L)
    {
        for( int i = 0; i <= L->last; i++)
            cout << L->data[i] << ' ';
        cout << endl << L->last + 1; 
    } 

    顺序表(传递引用)

    建表、输出

    void init_SeqList(SeqList &L)
    { 
        L.last = -1;       
    }
    //顺序表输出 
    void print(const SeqList &L)//const 避免 L 在该函数中被无意修改
    {
        for(int i = 0; i < L.last; i++)
            cout << L.data[i] << " ";
        cout << endl << L.last + 1;
    }
    

     插入

    Typedef Insert_SeqList(SeqList &L,int i,Typedef x)
    {
        if(L.last==MAXSIZE-1)
        {
            printf("Full");return (-1);
        }
        if(i<1 || i>L.last+2)
        {
            printf("wrong");return (0);
        }
        for(int j=L.last; j>=i-1; j--)
            L.data[j+1]=L.data[j];
        L.data[i-1]=x;
        L->last++;
        return 1;
    }

    删除

    Typedef Delete_SeqList(SeqList &L,int i)
    {
        if(i<0 || i>L.last)
        {
            printf("wrong");return 0;
        }
        for(int j=i; j<L.last; j++)
            L.data[j]=L.data[j+1];
        L->last--;
        return 1;
    }

    交换前后两部分:先整体反向,再在每部分反向。

    删除顺序表中多余的元素

    void purge_SeqList(SeqList &L)
    {
        k=-1;
        for(int i=0;i<=L.last;i++)
        {
            j=0;
            while(j<=k && L.data[i]!=L.data[j])
                ++j;
            if(k==-1 || j>k)
                L.data[++k]=L.data[i];
        }
        L.last=k;
    }
  • 相关阅读:
    关于C++名字空间
    选择组合OR继承?
    编译器为C++ 空类自动生成的成员函数
    函数返回值为引用类型
    关于数据库存储过程分页DatagridView BindingNavigator 控件的详细实现
    ADO.NET 安全编码指南 来自MSDN
    ADO.NET中调用存储过程
    视图
    高效使用连接的模式
    GROUP BY, HAVING, COMPUTE, ORDER BY 语句
  • 原文地址:https://www.cnblogs.com/Cindy-Chan/p/11178265.html
Copyright © 2011-2022 走看看