程序------>数据结构
一程序概念:
1.对身边的任何一个事物进行认知和分类,从而得到一些信息;
2.在得到的信息基础之上建立了概念模型;
3.根据概念模型将我们生活中的实际问题转换成计算机能理解的形式;
4.用户通过人机交互,从而解决实际生活中出现的问题!
二.数据结构:
就是用来反映一个概念模型的内部组成!也就是概念模型由那些具体的数据构成的!
三.线性结构:
1.数组:存储一系列相同类型的数据集合!在内存总会开辟一块连续的内存空间!
2.链表 : 单链表 双向链表 循环链表


//单链表
public class MyNode {
private int data; // 元素ABC的值
private MyNode next; // 下一个元素 public MyNode(int d){
data=d; //把用户传递来的值 给我们节点的元素
}
//用户传递来的下一个节点
private void append(MyNode myNode) {
MyNode node=this;
while(node.next!=null){
node=node.next;
}
node.next=myNode; //把传递过来的对象作为当前节点的下一个
} //要增加的节点
private void add(MyNode myNode) {
myNode.next=next;//把当前的null 给了传递过来节点的next属性
next=myNode;
} //显示链表中所有的节点
private void show() {
MyNode node=this;
while (node!=null){
System.out.println(node.data);
node= node.next;
}
} public static void main(String[] args) {
//创建我们自己的链表
MyNode node=new MyNode(10);
node.append(new MyNode(30));
node.append(new MyNode(40));
node.add(new MyNode(20));
node.show();
}
}
3.分叉关系:
01.图
02.树
03.二叉树
根节点 中间节点 叶子节点 左子树 右子树
根节点没有父节点!
中间节点有父节点也有子节点!
叶子节点没有子节点,但是有父节点!
4.遍历二叉树的两种方式:
01.前序遍历===》先根遍历===》 根=》左=》右
02.中序遍历===》 左=》根=》右
//二叉排序树
public class MyTree {
private int data; //树上的数据
private MyTree left; //左边
private MyTree right; //右边 public MyTree(int data){
this.data=data;
} //新增的树节点
private void add(MyTree myTree) {
if (myTree.data<this.data){
if (left==null){ //务必判断 否则数据会覆盖
left=myTree;
}else {
left.add(myTree);
}
}else{
if (right==null){ //务必判断 否则数据会覆盖
right=myTree;
}else {
right.add(myTree);
}
}
} //显示树上所有的数据
private void show() {
if (left!=null) left.show();
System.out.println(data); //中序
if (right!=null) right.sho
//二叉排序树
public class TreeDemo {
//创建集合保存所有节点
static List<Node> list=new ArrayList<>(); class Node{ //节点
String data; //值
String parent; //父节点的值
} //parent是父节点的值,child是子节点的值
private void add(String parent, String child) {
Node node=new Node();
node.data=child;
node.parent=parent;
list.add(node); //把数据放进集合
} //根据子节点查询对应的父节点
private static void showParent(String child) {
for (int i = 0; i < list.size(); i++) {
if (list.get(i).data.equals(child)){
System.out.println(list.get(i).parent);
}
}
}
//根据父节点查询对应的子节点
private static List<String> showChildren(String parent) {
List<String> children=new ArrayList<>();
for (int i = 0; i < list.size(); i++) {
if (list.get(i).parent.equals(parent)){
children.add(list.get(i).data);
}
}
return children;
} public static void main(String[] args) {
TreeDemo tree=new TreeDemo(); //创建一个空树
tree.add("学校","一年级");
tree.add("学校","二年级");
tree.add("学校","三年级");
tree.add("一年级","一年级1班");
tree.add("一年级","一年级2班");
tree.add("一年级","一年级3班");
tree.add("二年级","二年级1班");
tree.add("二年级","二年级2班");
tree.add("三年级","三年级1班"); //根据子节点查询对应的父节点
// showParent("二年级1班");
//根据父节点查询对应的子节点
showChildren("学校"); }
} public static void main(String[] args) { //创建一个树的根节点
MyTree tree=new MyTree(50);
tree.add(new MyTree(45));
tree.add(new MyTree(49));
tree.add(new MyTree(82));
tree.add(new MyTree(75));
tree.add(new MyTree(46));
tree.add(new MyTree(99));
tree.show();
}
}
程序------>数据结构的更多相关文章
- 初转java随感(一)程序=数据结构+算法
大学刚学编程的时候,有一句很经典的话程序=数据结构+算法 今天有了进一步认识. 场景: 1.当前局面 (1)有现成的封装好的分页组件 返回结果是page.类型为:Page.包括 page 分页信息,d ...
- Spark程序数据结构优化
场景: 1.scala中的对象:对象头是16个字节(包含指向对象的指针等源数据信息),如果对象中只有一个int的属性,则会占用20个字节,也就是说对象的源数据占用了大部分的空间,所以在封装数据的时候尽 ...
- (IOS)BaiduFM 程序分析
本文主要分享下楼主在学习Swift编程过程中,对GitHub上的一个开源app BaiduFM的研究心得. 项目地址:https://github.com/belm/BaiduFM-Swift 一.项 ...
- MySQL索引背后的数据结构及算法原理 --转
写在前面的话 在编程领域有一句人尽皆知的法则“程序 = 数据结构 + 算法”,我个人是不太赞同这句话(因为我觉得程序不仅仅是数据结构加算法),但是在日常的学习和工作中我确认深深感受到数据结构和算法的重 ...
- WinDbg 调试.net程序
WinDbg支持以下三种类型的命令: · 常规命令,用来调试进程 · 点命令,用来控制调试器 · 扩展命令,可以添加叫WinDbg的自定义命令,一般由扩展dl ...
- java程序练习:猜字母
猜字母程序=数据结构+算法 首先:定义数据结构1.找名词Input:输入变量Output:输出变量隐含:找到隐含的变量,如字符串 其次:定义算法,程序的处理 最后:按照顺序,逐步实现 注意:1.基本数 ...
- MySQL源码:索引相关的数据结构
http://www.orczhou.com/index.php/2012/11/mysql-source-code-data-structure-about-index/ 本文将尝试介绍MySQL索 ...
- 数据结构 Python实现
参考博客:浅谈算法和数据结构: 一 栈和队列 Python数据结构--栈.队列的实现(一) Python数据结构--栈.队列的实现(二) Python数据结构--链表的实现 数据结构 ...
- 数据结构(java版)学习笔记(序章)
程序=数据结构+算法 序章做一个简单的思维导图,方便理解数据结构这门课的大纲,接下来我们将是按照线性表,栈,队列,串,树和图的顺序依次往下学.
随机推荐
- Java知多少(63)线程间通信
上述例题无条件的阻塞了其他线程异步访问某个方法.Java对象中隐式管程的应用是很强大的,但是你可以通过进程间通信达到更微妙的境界.这在Java中是尤为简单的. 像前面所讨论过的,多线程通过把任务分成离 ...
- 51 IP核查询
康芯的IP核 Oregano systems 公司的MC8051 IP CoreSynthesizeable VHDL Microcontroller IP-Core User Guide这个里面51 ...
- TestLink汉化操作
实验环境版本 xampp-windows-x64-7.3.2-0-VC15-installer + testlink-1.9.19 汉化操作如下 打开testlink的配置文件F:\xampp\htd ...
- html5__Notifications API 桌面通知
MDN地址 google 文档 https://developers.google.cn/web/fundamentals/push-notifications/ const koa2 = requi ...
- 如何去除Launcher默认的google search bar?
JB2/JB3/JB5/JB9版本: 1. 请修改 Launcher2/res/layout/qsb_bar.xml,如下:<include android:id="@+id/qsb_ ...
- MySQL主从同步添加至zabbix监控
参考文档:https://blog.csdn.net/hellowidow_2020/article/details/78985368 https://www.cnblogs.com/cdjia ...
- 主席树||可持久化线段树||BZOJ 3524: [Poi2014]Couriers||BZOJ 2223: [Coci 2009]PATULJCI||Luogu P3567 [POI2014]KUR-Couriers
题目:[POI2014]KUR-Couriers 题解: 要求出现次数大于(R-L+1)/2的数,这样的数最多只有一个.我们对序列做主席树,每个节点记录出现的次数和(sum).(这里忽略版本差值问题) ...
- .NET Core开发日志——HttpClientFactory
当需要向某特定URL地址发送HTTP请求并得到相应响应时,通常会用到HttpClient类.该类包含了众多有用的方法,可以满足绝大多数的需求.但是如果对其使用不当时,可能会出现意想不到的事情. 博客园 ...
- autofac生命周期入门(如何避免内存泄漏)
如果你是一个IOC新手,那么生命周期可能会比较难以理解.以至于谈到这个问题时,一些老手也时常表示疑虑和害怕.一个令人不安的问题就是-对象没有在合适的时机被销毁.这样一来内存的使用率就会一直攀升,直到程 ...
- HDU 1166 - 敌兵布阵 - [分块]
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1166 题解: 本题作为一个模板题,我用它来检验过总查询时间复杂度为 $O(q \log n)$ 的树状 ...