zoukankan      html  css  js  c++  java
  • 链表

    1.list.h

    typedef int ElementType;
    
    #ifndef _List_H
    
    struct Node;
    typedef struct Node *PtrNode;
    typedef PtrNode List;
    typedef PtrNode Position;
    
    List MakeEmpty(List L);
    int IsEmpty(List L);
    int IsLast(Position P, List L);
    Position Find(ElementType X, List L);
    void Delete(ElementType X, List L);
    Position FindPrevious(ElementType X, List L);
    void Insert(ElementType X, List L, Position P);
    void DeleteList(List L);
    Position Header(List L);
    Position First(List L);
    Position Advance(Position P);
    ElementType Retrive(Position P);
    
    #endif
    

    2. fatal.h

    #include <stdio.h>
    #include <stdlib.h>
    
    #define Error( Str )   FatalError( Str )
    #define FatalError( Str )   fprintf( stderr, "%s
    ", Str ), getchar(); exit( 1 )
    

    3.list.c

    #include "list.h"
    #include <stdio.h>
    #include "fatal.h"
    
    struct Node
    {
    	ElementType Element;
    	Position Next;
    };
    Position Header(List L)
    {
    	return L;
    }
    
    Position First(List L)
    {
    	return L->Next;
    }
    
    Position Advance(Position P)
    {
    	return P->Next;
    }
    
    ElementType Retrieve(Position P)
    {
    	return P->Element;
    }
    
    int IsEmpty(List L)
    {
    	return L->Next == NULL;
    }
    
    int IsLast(Position P, List L)
    {
    	return P->Next == NULL;
    }
    
    Position Find(ElementType X, List L)
    {
    	Position P;
    
    	P = L->Next;
    	while (P != NULL && P->Element != X)
    		P = P->Next;
    
    	return P;
    }
    
    void Delete(ElementType X, List L)
    {
    	Position P, TmpCell;
    	
    	P = FindPrevious(X, L);
    	if (!IsLast(P,L))
    	{
    		TmpCell = P->Next;
    		P->Next = TmpCell->Next;
    		free(TmpCell);
    	}
    }
    
    Position FindPrevious(ElementType X, List L)
    {
    	Position P;
    
    	P = L;
    	while (P->Next != NULL && P->Next->Element != X)
    		P = P->Next;
    
    	return P;
    }
    
    void Insert(ElementType X, List L, Position P)
    {
    	Position TmpCell;
    	TmpCell = malloc(sizeof(struct Node));
    	if (TmpCell == NULL)
    	{
    		FatalError("Out of Space!!!");
    	}
    	TmpCell->Element = X;
    	TmpCell->Next = P->Next;
    	P->Next = TmpCell;
    }
    
    List MakeEmpty(List L)
    {
    	if (L!= NULL)
    	{
    		DeleteList(L);
    	}
    
    	L = malloc(sizeof(struct  Node));
    	if (L == NULL)
    	{
    		FatalError("out of space!!!");
    	}
    	L->Next = NULL;
    	return L;
    }
    
    void DeleteList(List L)
    {
    	Position P, TmpCell;
    	P = L->Next;
    	L->Next = NULL;
    
    	while (P != NULL)
    	{
    		TmpCell = P->Next;
    		free(P);
    		P = TmpCell;
    	}
    }
    
    ElementType MaxValue(List L)
    {
    	ElementType MaxData = 0;
    
    	Position P = L->Next;
    	while (P != NULL)
    	{
    		if (MaxData < P->Element)
    		{
    			MaxData = P->Element;
    		}
    	}
    
    	return MaxData;
    }
    

    4.testlist.c

    #include "list.h"
    #include <stdio.h>
    #include <stdlib.h>//system("pause");
    
    void PrintList(const List L)
    {
    	Position P = Header(L);
    
    	if (IsEmpty(L))
    		printf("Empty list
    ");
    	else
    	{
    		do
    		{
    			P = Advance(P);
    			printf("%d ", Retrieve(P));
    		} while (!IsLast(P, L));
    		printf("
    ");
    	}
    }
    
    int mainTest()
    {
    	List L;
    	Position P;
    	int i;
    
    	L = MakeEmpty(NULL);
    	P = Header(L);
    	PrintList(L);
    
    	for (i = 0; i < 10; i++)
    	{
    		Insert(i, L, P);
    		PrintList(L);
    		P = Advance(P);
    	}
    	for (i = 0; i < 10; i += 2)
    		Delete(i, L);
    
    	for (i = 0; i < 10; i++)
    	{
    		if ((i % 2 == 0) == (Find(i, L) != NULL))
    			printf("Find fails
    ");
    
    		printf("%d %% 2 =%d	%d
    ", i, i % 2, Find(i, L) != NULL);
    	}
    
    
    	printf("Finished deletions
    ");
    
    	PrintList(L);
    
    	DeleteList(L);
    
    	system("pause");
    	return 0;
    }
    
    int main()
    {
    	List L;
    	Position P;
    	int i;
    
    	L = MakeEmpty(NULL);
    	P = Header(L);
    	PrintList(L);
    	int data = 0;
    	for (i = 0; i < 10; i++)
    	{
    		data = rand() % 1000;
    		Insert(data, L, P);
    		PrintList(L);
    		P = Advance(P);
    	}
    
    	printf("Finished deletions
    ");
    	PrintList(L);
    	DeleteList(L);
    	PrintList(L);
    	system("pause");
    	return 0;
    }
    

      

  • 相关阅读:
    android 生命周期图
    c++中 箭头> 双冒号:: 点号.操作符区别
    Blocks 笔记
    使用AVAudioRecorder 录音
    音频输入大小变化图
    【Linux】本机与服务器文件互传、Linux服务器文件上传下载
    【Oracle】Oracle解锁、Oracle锁表处理
    使用three.js创建3D机房模型分享一
    WPF下递归生成树形数据绑定到TreeView上
    (转载)C++抽象工厂模式(大话设计模式)
  • 原文地址:https://www.cnblogs.com/my-cat/p/5969008.html
Copyright © 2011-2022 走看看