C++ 中常用的一些东西,通过使用动态数组来实现顺序表, 掌握了一下知识点: 1.预处理有三中方法 宏定义,文件包含,条件编译 2.使用同名的变量时,可以在外层使用命名空间 类解决变量名重定义的错误 3.类中三个访问权限, public : 公有访问权限,主要写一些函数接口 protected: 保护访问 private     私有访问权限      封装性, 4.构造函数\析构函数 5.重载运算符 sub.h文件 /* 实现一个顺序表 1.创建类.成员包含.指向顺序表的指针,顺序表的长度,顺…
在数据结构中包含两种,一种线性结构(包括顺序表,链表,栈,队列),一种非线性结构(树,图), 顺序表,其实就是在内存动态数组,Java中的ArrayList就是一个典型的顺序表,它在顺序表的基础上增加了扩容机制,单实质还是一个顺序表 下面分三步, 1创建一个顺序表结构, 2.贴出所有操作的代码 3.最终测试 第一,创建顺序表结构 struct Arr { int *pBase; int len;//总长度 int cnt;//当前长度 }; 所有声明 void init_arr(struct A…
今天本来想写段代码练练手,想法挺好结果,栽了个大跟头,在这个错误上徘徊了4个小时才解决,现在分享出来,给大家提个醒,先贴上代码: /******************************************** * 文件名称:sqlist.h * 文件描述:线性表顺序存储演示 * 文件作者:by Wang.J,in 2013.11.16 * 文件版本:1.0 * 修改记录: *********************************************/ #ifndef _…
说明:将元素x插入到顺序表L的第i个数据元素之前,这个i是从1开始的,但是程序中数组都是从0算起的,不要混淆了. 头文件: header.h // 顺序表的结构定义 #define Maxsize 100 //const int Maxsize = 100; // 预先定义一个足够大的常数 typedef struct { int data[Maxsize]; // 存放数组的数组 int length; // 顺序表的实际长度 }SeqList; // 顺序表类型名为SeqList // Se…
顺序表结构可设为一个数组和一个指向尾部的变量,数组用来存放元素,指向尾部的变量在插入元素的时候加一,删除元素的时候减一,始终指向尾部. typedef int elemtype; typedef struct arrayList{ elemtype date[MAXSIZE]; int last; }ArrayList; 初始化时给对应的指针分配空间,并使last=-1 ArrayList *init_ArrayList(){ ArrayList *a = (ArrayList *)malloc…
01 数据结构基本概念_大O表示法 无论n是多少都执行三个具体步骤 执行了12步 O(12)=>O(1) O(n) log 2 N = log c N / log c N (相当于两个对数进行了一次运算) 所以就不记入底数了,记作 O(logN) 资料: (对数函数 a ≠ 1 O(logN) O(n^2) n+(n-1)+(n-2)+ … 1 = n*(n+1)/2 只关注最高次项n/2社区 n^2/2 O(n^2) 02 线性表基本概念 03 动态数组框架搭建   vector如何动态增长的…
[Java心得总结六]Java容器中——Collection在前面自己总结的一篇博文中对Collection的框架结构做了整理,这里深究一下Java中list的实现方式 1.动态数组 In computer science, a dynamic array, growable array, resizable array, dynamic table, mutable array, or array list is a random access, variable-size list data…
听黑马程序员教程<基础数据结构和算法 (C版本)>,照着老师所讲抄的, 视频地址https://www.bilibili.com/video/BV1vE411f7Jh?p=1 喜欢的朋友可以去看看. 动态数组 #include<stdio.h> #include<stdlib.h> #include<string.h> /* 动态数组,视频地址https://www.bilibili.com/video/BV1vE411f7Jh?spm_id_from=33…
先来个开胃菜 // 使用new动态分配存储空间 #include<iostream> using std::cout; int main() { // 第1种方式 int *a=new int; *a=; cout<<"使用第一种方式进行动态分配存储空间的结果为:\n" <<"*a= "<<*a<<std::endl; delete a; // 释放动态存储空间 // 第2种方式 ); cout<&l…
#include <stdio.h> #include <stdlib.h> typedef int EmenType; typedef struct Node { int data; struct Node *next; Node() { next = NULL; } } node, *Link; bool Init(Link head); bool Insert(Link, int i, EmenType e); bool Delete(Link p, int i, EmenT…