1、数据结构概念

  所谓的数据结构是数据之间的关系,都是为了提高程序效率而设计的。

  分为逻辑关系和物理关系两种。

  逻辑关系:人为的一种逻辑思维的认为。

    (1)集合:在一个范围内有多个数据,数据之间没有关系

    (2)线性:1对1的关系

    (3)树型:1对多的关系

    (4)图:多对多

  物理关系:内存存储的一种关系。

    (1)顺序存储:数组方式

    (2)链式存储:链表方式

2、算法

  (1)大数据的运算

  例如:很大的阶层运算,1*2*3*...*50=?

public class DataStratum01 {

    public static void main(String[] args) {

        // 10的阶层计算
int n = 50; int[] datas = new int[100];
datas[datas.length - 1] = 1;
for (int i = 1; i <= n; i++) {
cal(datas, i);
} for (int i = 0; i < datas.length; i++) {
System.err.print(datas[i]);
}
} /* 计算阶层 */
public static int[] cal(int[] datas, int num) { for (int i = 0; i < datas.length; i++) {
datas[i] *= num;
} for (int i = datas.length - 1; i > 0; i--) {
int temp = datas[i] / 10;
if (temp > 0) {
datas[i - 1] += temp;
}
datas[i] %= 10;
} return datas;
}
}

  (2)插入排序运算

public class DataInsertSort {
public static void main(String[] args) {
// 插入排序:方法一,用到了三个循环 int[] datas = {7,3,8,2,1,9,4,5}; for (int i = 1; i < datas.length; i++) {
if (datas[i] < datas[i - 1]) { // 当发现i的位置小于i-1的位置的时候
for (int j = 0; j < i; j++) {
if (datas[i] < datas[j]) { // 当发现i的位置小于j的位置时候
int temp = datas[i];
for (int k = i - 1; k >= j; k--) { // k位置的数据往后移动
datas[k + 1] = datas[k];
}
datas[j] = temp;
}
}
}
} for (int i = 0; i < datas.length; i++) {
System.out.print(datas[i]);
}
}
}

  结果:

  (3)查找数据

  例如:二分查找法

public class DataBinarySearch {
// 二分查找法
public static void main(String[] args) { int[] datas = {2, 4, 7, 8, 10, 12, 16, 19, 20};
int num = 1;
int start = 0; // 开始位置
int end = datas.length - 1; // 末尾位置
int centre = 0; // 中间位置,默认0
while (start <= end) {
centre = (start + end) / 2; // 获取中间位置
if (num == datas[centre]) { // 如果找到
System.err.println("存在需要查找的数据:所在为主-" + centre + ", 数字为-" + num);
return ;
}
if (num < datas[centre]) { // 需要查找的数据在中间位置的左边
end = centre - 1;
} else { // 需要查找的数据在中间位置的右边:num > datas[centre]
start = centre + 1;
}
}
System.err.println("不存在需要查找的数据!");
}
}

3、其他

有关数据结构与算法的知识还有:

1)ArrayList和LinkList原理,代码实现,性能区别。

2)栈和队列的代码实现。

3)递归:文件夹遍历,八皇后,汉罗塔,寻址。

4)二叉树:堆排序,中排序以及图。

后面会一一讲解和实现。

java数据结构与算法(一)的更多相关文章

  1. Java数据结构和算法

    首先,本人自学java,但是只学习了java的基础知识,所以想接下来学习一下数据结构和算法,但是找了很多教材,大部分写的好的都是用c语言实现的,虽然知道数据结构和算法,跟什么语言实现的没有关系,但是我 ...

  2. 【Java数据结构学习笔记之二】Java数据结构与算法之栈(Stack)实现

      本篇是java数据结构与算法的第2篇,从本篇开始我们将来了解栈的设计与实现,以下是本篇的相关知识点: 栈的抽象数据类型 顺序栈的设计与实现 链式栈的设计与实现 栈的应用 栈的抽象数据类型   栈是 ...

  3. Java数据结构和算法(六)——前缀、中缀、后缀表达式

    前面我们介绍了三种数据结构,第一种数组主要用作数据存储,但是后面的两种栈和队列我们说主要作为程序功能实现的辅助工具,其中在介绍栈时我们知道栈可以用来做单词逆序,匹配关键字符等等,那它还有别的什么功能吗 ...

  4. Java数据结构和算法(十四)——堆

    在Java数据结构和算法(五)——队列中我们介绍了优先级队列,优先级队列是一种抽象数据类型(ADT),它提供了删除最大(或最小)关键字值的数据项的方法,插入数据项的方法,优先级队列可以用有序数组来实现 ...

  5. Java数据结构和算法(九)——高级排序

    春晚好看吗?不存在的!!! 在Java数据结构和算法(三)——冒泡.选择.插入排序算法中我们介绍了三种简单的排序算法,它们的时间复杂度大O表示法都是O(N2),如果数据量少,我们还能忍受,但是数据量大 ...

  6. java数据结构与算法之栈(Stack)设计与实现

    本篇是java数据结构与算法的第4篇,从本篇开始我们将来了解栈的设计与实现,以下是本篇的相关知识点: 栈的抽象数据类型 顺序栈的设计与实现 链式栈的设计与实现 栈的应用 栈的抽象数据类型 栈是一种用于 ...

  7. Java数据结构和算法 - 堆

    堆的介绍 Q: 什么是堆? A: 这里的“堆”是指一种特殊的二叉树,不要和Java.C/C++等编程语言里的“堆”混淆,后者指的是程序员用new能得到的计算机内存的可用部分 A: 堆是有如下特点的二叉 ...

  8. Java数据结构和算法 - 二叉树

    前言 数据结构可划分为线性结构.树型结构和图型结构三大类.前面几篇讨论了数组.栈和队列.链表都是线性结构.树型结构中每个结点只允许有一个直接前驱结点,但允许有一个以上直接后驱结点.树型结构有树和二叉树 ...

  9. Java数据结构和算法 - 高级排序

    希尔排序 Q: 什么是希尔排序? A: 希尔排序因计算机科学家Donald L.Shell而得名,他在1959年发现了希尔排序算法. A: 希尔排序基于插入排序,但是增加了一个新的特性,大大地提高了插 ...

  10. Java数据结构和算法 - 递归

    三角数字 Q: 什么是三角数字? A: 据说一群在毕达哥拉斯领导下工作的古希腊的数学家,发现了在数学序列1,3,6,10,15,21,……中有一种奇特的联系.这个数列中的第N项是由第N-1项加N得到的 ...

随机推荐

  1. Matlab人脸检測方法(Face Parts Detection)具体解释

    今天同学让我帮忙制作一个人脸表情识别的样本库,当中主要是对人脸进行裁剪,这里用到了一个相对较新的Matlab人脸检測方法Face Parts Detection.网上百度了一下发现关于Matlab人脸 ...

  2. 获取本地ip

    public void GetLocalIP(string username) { List<string> strIPs = new List<string>(); Netw ...

  3. java-生成任意格式的json数据

    最近研究java的东西.之前靠着自己的摸索,实现了把java对象转成json格式的数据的功能,返回给前端.当时使用的是 JSONObject.fromObject(object) 方法把java对象换 ...

  4. html5中将图片的绝对路径转换成文件对象

    html5中将图片的绝对路径转换成文件对象 将图片的绝对路径转换成base64编码,请看这篇文章 我们先来理解基本知识点: 1. 理解HTML5中的FileList对象与file对象. 在HTML5中 ...

  5. 数据分析与展示——Pandas数据特征分析

    Pandas数据特征分析 数据的排序 将一组数据通过摘要(有损地提取数据特征的过程)的方式,可以获得基本统计(含排序).分布/累计统计.数据特征(相关性.周期性等).数据挖掘(形成知识). .sort ...

  6. js判断文件类型大小并给出提示

    上传文件是工作中常用的功能,不同的场景对不同的文件类型和文件大小都有不同的要求: <form id="uploadForm" method="post" ...

  7. mongodb命令行基础语法

    首先是安装并配置mongodb,这个请自行百度,安装完成后打开cmd命令输入mongo.我们现在先做一个例子吧,假设有一个班级叫c1,里面有若干个人,里面的人有姓名.年龄.性别和班级,我们分别对他们进 ...

  8. iOS UIAlertController在Tableview中显示缓慢,迟钝,延迟

    在UITableViewCell中弹窗Alert延迟.在cellForRow中:cell.selectionStyle = UITableViewCellSelectionStyleNone; 或者在 ...

  9. linux部署solr服务--小记

    1.将solr压缩包上传到web项目-solr文件夹下 2.解压solr-5.5.4.zip到当前文件夹下 linux 解压zip文件到当前目录 unzip filename.zip 提示没有unzi ...

  10. 在一个终端后台运行的进程在新的终端中使用job不会被发现

    我在一个终端后台运行了一个程序.之后由于工作需要又新开了一个新的终端.在新的终端中,我想查看后台程序的运行状态,输入jobs时,发现没有后台任务运行.难道我的程序死掉了?我接着top了下,发现我的后台 ...