数据结构3-4周总结(1) 基本操作

借鉴了无数大佬的代码 还有自己一遍遍修改后
终于“踉踉跄跄”地完成了自己的作业 但感觉还有很多不足 写几篇来总结一下近日所学

链表操作:

裁判程序

#include <stdio.h>
#include <stdlib.h>

#define MAXSIZE 5
#define ERROR -1
typedef enum {false, true} bool;
typedef int ElementType;
typedef int Position;
typedef struct LNode *List;
struct LNode {
    ElementType Data[MAXSIZE];
    Position Last; /* 保存线性表中最后一个元素的位置 */
};

List MakeEmpty(); 
Position Find( List L, ElementType X );
bool Insert( List L, ElementType X, Position P );
bool Delete( List L, Position P );

int main()
{
    List L;
    ElementType X;
    Position P;
    int N;

    L = MakeEmpty();
    scanf("%d", &N);
    while ( N-- ) {
        scanf("%d", &X);
        if ( Insert(L, X, 0)==false )
            printf(" Insertion Error: %d is not in.\n", X);
    }
    scanf("%d", &N);
    while ( N-- ) {
        scanf("%d", &X);
        P = Find(L, X);
        if ( P == ERROR )
            printf("Finding Error: %d is not in.\n", X);
        else
            printf("%d is at position %d.\n", X, P);
    }
    scanf("%d", &N);
    while ( N-- ) {
        scanf("%d", &P);
        if ( Delete(L, P)==false )
            printf(" Deletion Error.\n");
        if ( Insert(L, 0, P)==false )
            printf(" Insertion Error: 0 is not in.\n");
    }
    return 0;
}

List MakeEmpty():创建并返回一个空的线性表;

Position Find( List L, ElementType X ):
返回线性表中X的位置。若找不到则返回ERROR;

bool Insert( List L, ElementType X, Position P ):
将X插入在位置P并返回true。若空间已满,则打印“FULL”并返回false;
如果参数P指向非法位置,则打印“ILLEGAL POSITION”并返回falsebool Delete( List L, Position P ):将位置P的元素删除并返回true。
若参数P指向非法位置,
则打印“POSITION P EMPTY”(其中P是参数值)并返回false

顺序表操作集

//创建并返回一个空链表

List MakeEmpty(){
	List L =(List)malloc(sizeof(struct LNode));
	L->Last=-1;
	return L;
}
//返回线性表中X的位置。若找不到则返回ERROR;
Position Find( List L, ElementType X ){
	 for(Position i=0;i<=L->Last;i++){
        if(L->Data[i]==X){return i;}
    }return ERROR;
bool Insert( List L, ElementType X, Position P ):
将X插入在位置P并返回true。
若空间已满,则打印“FULL”并返回false;
如果参数P指向非法位置,则打印“ILLEGAL POSITION”并返回falsebool Insert( List L, ElementType X, Position P ){
	int k;
	if(L->Last==MAXSIZE-1){
		printf("FULL");
		return false; 
	}
	if(p<1||p>L->Last+2){
		printf("ILLEGAL POSITION");
		return false;
	}
	for(int i-L->Last;i>P;i--){
		L->Data[i+1]=L->Data[i];
		
	}
	L->Data[P]=X;
	L->Last++;
	return true;
	
	
	
}
bool Delete( List L, Position P ):
将位置P的元素删除并返回true。
若参数P指向非法位置,则打印“POSITION P EMPTY”
(其中P是参数值)并返回falsebool Delete( List L, Position P ){
	if(P<0||P>L->Last){
		printf("POSITION %d EMPTY",P);
		return false;
	}
	for(int i=P;i<L->Last;i++){
		L->Data[i]=L->Data[i+1];
		
	}
	L->Last--;
	return true;
	
	
	
}

和课本上不一样的是 判断的都是P<0||P>L->last
而书上是P<1||P>L->Last 是书和题的差别还是我写的有问题呢?

©️2020 CSDN 皮肤主题: 深蓝海洋 设计师:CSDN官方博客 返回首页