通过五种不同的常用编程语言封装常用数据结构的基结构

定义:

数据结构是相互之间存在一种或多种特定关系的数据元素的集合。

在任何问题中,数据元素都不是孤立存在的,而是在它们之间存在着某种关系,这种数据元素之间的关系,称之为“结构”,有根据数据元素之间关系的不同特性,通常就分成了下面的4中基本的结构:

集合:

image

线性结构:

image

树:

image

图状或者网状结构:

image

先简单通过4张图片来了解一下,后面的文章会一一详细的讲解

数据元素之中的结构有两种不同的表示方法:顺序和非顺序 因此计算机中有两种不同的存储结构:顺序存储结构链式存储结构

接下来说说我们要封装的基结构,关于所说的基结构可以这样理解,为所有数据结构的共同特性,那么我们要封装什么呢?

  • 数据对象

  • 数据之间的关系

  • 基本的操作(初始化,插入,删除,获取所有值,获取值等基本的一些操作)

接下来就开始我们的封装

C语言

c封装起来确实比较麻烦,C语言是面向过程的语言,但是我们可以用结构体模拟面向对象来对其进行封装

代码如下:

#include<stdio.h>
#define BaseStruct LinkList//标注BaseStruct现在是什么类型 比如说现在是列表 对列表进行操作
typedef int BaseType;//定义baseStruct的基本类型
typedef struct node{
    BaseType data;
    struct node *next;
} Node;//链式存储需要用到这样的一个节点结构
typedef struct basestruct{
    BaseType *header;//不管是什么存储结构都会有一个头,通过开头地址就能找到下一个元素
    void (*initData)();//初始化数据
    void (*insert)();//插入数据
    void (*removeh)();//删除值 remove有函数用了这个名字所以换成removeh
    void (*printbs)();//打印bs
}BaseStruct;
void initData(BaseStruct bs){}
void insert(BaseStruct bs){}
void removeh(BaseStruct bs){}
void printbs(BaseStruct bs){}
//这里先做个简单的演示,还有其他的一些共有的方法
void main(){
    BaseStruct a;
    a.initData=initData;
    a.insert=insert;
    a.removeh=removeh;
    a.printbs=printbs;
    a.initData();
    a.insert();
    a.removeh();
    a.printbs();
    //getchar();
  
}

PHP

php实现起来就比较简单了,通过面向对象的思考方法可以让封装变得很简单

<?php
    //基接口
    interface BaseStructImpl{
        //public function initData();关于php可以不用进行initData 因为php为自动为你的变量分配地址
        public function insert();
        public function remove();
        public function print_bs();//打印所有的数据
    }
    //顺序存储结构
    class BaseStruct implements BaseStructImpl{
        private $data;//顺序存储结构可以通过数组来实现存储
        public function __construct($d){
            //可以在这里进行初始化数据
            $this->data=$d;
        }
        public function insert(){}
        public function remove(){}
        public function print_bs(){}//
    }
    //模拟链式存储结构
    class Node{
        public $data;
        public $next=null;
    }
    class LinkedBaseStruct implements BaseStructImpl{
        private $header;//顺序存储结构可以通过数组来实现存储
        public function __construct(){
            //可以在这里进行初始化数据
            $head=new Node();
            $head->data="头节点的值";
            //$head->next=new Node();
        }
        public function add(){}
        public function insert(){}
        public function remove(){}
        public function print_bs(){}
    }
    
?>

JAVA

java跟php的写法差不多 我就不多说什么了

interface BaseStructImpl{
    public void insert();
    public void remove();
    public void print_bs();
}
//顺序存储结构
class BaseStruct implements BaseStructImpl{
    public int[] data;//10个长度大小的int型顺序型存储结构
    public BaseStruct(){
        this.data=new int[10];
    };
    public void insert(){};
    public void remove(){};
    public void print_bs(){};
}
//链式存储结构
class Node{
    public int data;
    public Node next=null;
}
class LinkedBaseStruct implements BaseStructImpl{
    public Node head;
    public LinkedBaseStruct(){
        this.head=new Node();
    }
    public void insert(){};
    public void remove(){};
    public void print_bs(){};
    
}

Python

python没有接口 但是我们可以通过继承类来实现

class BaseStructImpl:
    def insert(self):
        pass
    def remove(self):
        pass
    def print_bs(self):
        pass
#顺序存储结构
class BaseStruct(BaseStructImpl):
    def __init__(self,d):
        self.data=d#顺序存储简单
        pass
    def insert(self):
        pass
    def remove(self):
        pass
    def print_bs(self):
        pass
#链式存储结构
class Node:
    def __init__(self,d):
        self.data=d
        self.next=None;
class LinkedBaseStruct(BaseStructImpl):
     def __init__(self):
         self.head=Node(1)
         pass
     def insert(self):
         pass
     def remove(self):
         pass
     def print_bs(self):
         pass
        

node.js

//在node.js中引进了面向对象的方法
class BaseStructImpl{
    insert(){};
    remove(){};
    print_bs(){};
}
//顺序存储结构
class BaseStruct extends BaseStructImpl{
    constructor(d){
        this.data=d;
    };
    insert(){};
    remove(){};
    print_bs(){};
}
//链式存储结构
class Node{
    //注意点:class定义的成员变量只能在constructor里面定义和初始化
    //这一点和function不同
    constructor(d){
        this.next=null;
        this.data=d;
    }
}
class LinkedBaseStruct extends BaseStructImpl{
    constructor(d){
        this.head=new Node(1);
    }
    insert(){};
    remove(){};
    print_bs(){};
}

总结

这篇文章是我在学习数据结构的时候写的一篇学习笔记,如果文章中有什么写的不对的地方请大神进行指点。谢谢。下一篇文章将继续通过这种方式来继续学习数据结构。

参考书籍

严蔚敏教授的《数据结构》

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,951评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,606评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,601评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,478评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,565评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,587评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,590评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,337评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,785评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,096评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,273评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,935评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,578评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,199评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,440评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,163评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,133评论 2 352