java5 - 数组与排序算法
数组是什么?
### 一、[一维数组](http://baike.baidu.com/item/%E4%B8%80%E7%BB%B4%E6%95%B0%E7%BB%84?sefr=cr)
1 声明与定义的区别
一般的情况下我们常常这样叙述,
把建立空间的声明称之为"定义",
而把不需要建立存储空间称之为"声明".
很明显我们在这里指的声明是范围比较窄的,
也就是说非定义性质的声明。
// 1、声明
int a[];
int[] b;
// 2、定义
a = new int[5];
b = new int[5];
// 3、赋值
a[0] = 1;
a[1] = 2;
a[2] = 3;
a[3] = 4;
a[4] = 5;
// 4、定义
int[] a = new int[10];
int a[] = new int[10];
// 5、定义并初始化
int[] a = {1,2,3,4};
int[] a = new int[]{1,2,3,4};
1.2 运用
- 数组名表示什么?
- arr[0]表示什么?
- 怎么获取数组长度?
- 如何使用数组下标取值?
- 如何输出数组中所有的元素?
- 如何给数组中所有元素求和?
- 如何找出数组中最大值,最小值?
- 如何判断数组中是否包含某一个值?
- 如何去除数组中的重复元素?
- 如何求两个数组元素的交集与并集?
- 如何判断两个数组是包含的元素值都相同?
练习:
一个班有10个同学的数学成绩需要记录,
要计算班级
总成绩,
平均成绩,
最高分,
最低分,
及格人数等数据。
二、二维数组
2.1 二维数组其实就是矩阵。
2.2 声明、定义与初始化
// 声明
int a[][];
int[][] b;
// 第一次给一个声明的变量赋值叫做初始化
a = new int[][]{{1,1,1},{2,2,2}};
// 定义
int c[][] = {{1,1,1},{2,2,2}};
int[][] d = {{1,1,1},{2,2,2}};
2.3 运用
练习1
// 某校幼儿园有3个班,每个班有5个人,计算各班平均年龄?计算全园平均年龄?计算总人数?
int students[][] = { { 3, 6, 4, 5, 4 }, { 2, 3, 5, 3, 2 }, { 3, 4, 6, 2, 4 } };
int[][] students = { { 3, 6, 4, 5, 4 }, { 2, 3, 5, 3, 2 }, { 3, 4, 6, 2, 4 } };
练习2
1. 打印出杨辉三角?
### 三、数组排序

3.1、选择排序
int[] array1 = { 2, 3, 1, 5, 4 };
// 控制遍历的次数
for (int i = 0; i < array1.length - 1; i++) {
// int min = array1[i]; // 默认最小值
int minIndex = i; // 记录最小值的下标
// 找出最小值
for (int j = i + 1; j < array1.length; j++) {
if (array1[j] < array1[minIndex]) {
minIndex = j;
}
}
// 如果最小值不在最前面,和最前面做交换
if (minIndex != i) {
int temp = array1[i];
array1[i] = array1[minIndex];
array1[minIndex] = temp;
}
}
// 输出
System.out.println("选择排序之后:");
for (int i = 0; i < array1.length; i++) {
System.out.println("array1[" + i + "] = " + array1[i]);
}
3.2、冒泡排序
int array3[] = { 1, 3, 4, 6, 2, 11, 19, 2, 7, 0 };
// 控制遍历次数
for (int i = 0; i < array3.length - 1; i++) {
// 控制比较交换
for (int j = 0; j < array3.length - i - 1; j++) {
// 控制交换条件
if (array3[j] > array3[j + 1]) {
int temp = array3[j];
array3[j] = array3[j + 1];
array3[j + 1] = temp;
}
System.out.print("array3 第" + (i + 1) + "次冒泡,第" + (j + 1) + "比较结束:");
for (int i1 = 0; i1 < array3.length; i1++) {
System.out.print("," + array3[i1]);
}
System.out.println("");
}
System.out.print("array3 第" + (i + 1) + "次冒泡结束:");
for (int i1 = 0; i1 < array3.length; i1++) {
System.out.print("," + array3[i1]);
}
System.out.println("");
}
System.out.println("array3 冒泡排序之后:");
for (int i = 0; i < array3.length; i++) {
System.out.println("array3[" + i + "] = " + array3[i]);
}
3.3、直接插入排序
int array6[] = { 3, 4, 2, 1, 5, 6, 9, 8, 7, 0 };
/**
* 2 2,3,4
*/
for (int i = 1; i < array6.length; i++) {
int j = i; // 2, i = 2 ; j = 2
int temp = array6[i];
while (j > 0 && temp < array6[j - 1]) {
array6[j] = array6[j - 1]; // array6[2] = array6[1];
j--;
}
System.out.println("第" + i + "次移动后:");
for (int i1 = 0; i1 < array6.length; i1++) {
System.out.print("," + array6[i1]);
}
System.out.println();
array6[j] = temp;
}
System.out.println("array6 直接插入排序之后:");
for (int i = 0; i < array6.length; i++) {
System.out.println("array6[" + i + "] = " + array6[i]);
}
3.4、阶乘
/**
* 1! = 1
* 2! = 2 x 1 = 2 x 1!
* 3! = 3 x 2 x 1 = 3 x 2!
* 4! = 4 x 3 x 2 x 1 = 4 x 3!
* ......
*/ static int Factorial(int n) {
// return n*(n-1)!
if (n < 1) {
return 0;
}
if (n == 1) {
return 1;
} else {
return n * Factorial(n - 1);
}
}
3.5、归并排序
static void MSort(int[] arr, int left, int right) {
int mid = (left + right) / 2;
if (left < right) {
// 递归拆分左边
MSort(arr, left, mid);
// 递归拆分右边
MSort(arr, mid + 1, right);
// 将拆分的有序数组排序
Merge(arr, left, mid, right);
}
}
static void Merge(int[] arr, int left, int mid, int right) {
int[] temp = new int[right - left + 1];
int low1 = left; // 左边数组的起始位置
int low2 = mid + 1; // 右边数组的起始位置
int index = 0;
// 比较拆分的两个子数组,依次取最小值,放入新数组
while (low1 <= mid && low2 <= right) {
if (arr[low1] <= arr[low2]) {
temp[index++] = arr[low1++];
} else {
temp[index++] = arr[low2++];
}
}
// 把左边剩余的装进新数组
while (low1 <= mid) {
temp[index++] = arr[low1++];
}
// 把右边剩余的装进新数组
while (low2 <= right) {
temp[index++] = arr[low2++];
}
//把新数组里面的有序元素数,装进原数组
for (int i = 0; i < temp.length; i++) {
arr[i + left] = temp[i];
}
}
java5 - 数组与排序算法的更多相关文章
- Java数组的排序算法
在Java中,实现数组的排序算法有很多,如冒泡排序法.选择排序法.直接插入法和快速排序法等.下面介绍几种排序算法的具体 实现. 本文引用文献:Java必须知道的300个问题. 1.冒泡排序法 1.1 ...
- Shell数组以及排序算法(冒泡、直接选择、反转)
Shell数组以及排序算法(冒泡.直接选择.反转) 目录 Shell数组以及排序算法(冒泡.直接选择.反转) 一.数组概述 1. 数组的定义 2. 下标的定义 3. 数组的特点 4. 数组定义的方法 ...
- 02-Java 数组和排序算法
一.Java 数组 1.数组定义:数组是有序数据的集合,数组中的每个元素具有相同的数组名和下标来做唯一标识. 2.数组的分类:一维.二维.三维. 3.数组声明及内存分配: 为数组分配内存空间:如果不分 ...
- PHP数组基本排序算法和查找算法
关于PHP中的基础算法,小结一下,也算是本博客的第一篇文章1.2种排序算法冒泡排序:例子:个人见解 5 6 2 3 7 9 第一趟 5 6 2 3 7 9 5 2 6 3 7 9 5 2 3 6 7 ...
- java基础---数组的排序算法(3)
一.排序的基本概念 排序:将一个数据元素集合或序列重新排列成按一个数据元素某个数据项值有序的序列 稳定排序:排序前和排序后相同元素的位置关系与初始序列位置一致(针对重复元素来说,相对位置不变) 不稳定 ...
- java se系列(四) 函数、数组、排序算法、二分法、二维数组
1 函数 1.1 数的概述 发现不断进行加法运算,为了提高代码的复用性,就把该功能独立封装成一段独立的小程序,当下次需要执行加法运算的时候,就可以直接调用这个段小程序即可,那么这种封装形形式的具体表 ...
- hiho一下 第四十八周 拓扑排序·二【拓扑排序的应用 + 静态数组 + 拓扑排序算法的时间优化】
题目1 : 拓扑排序·二 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi和小Ho所在学校的校园网被黑客入侵并投放了病毒.这事在校内BBS上立刻引起了大家的讨论,当 ...
- C# 实现二维数组的排序算法(代码)
class Order { /// <summary> /// 对二维数组排序 /// </summary> /// <param name="values&q ...
- 排序图解:js排序算法实现
之前写过js实现数组去重, 今天继续研究数组: 排序算法实现. 排序是数据结构主要内容,并不限于语言主要在于思想:大学曾经用C语言研究过一段时间的排序实现, 这段时间有空用JS再将排序知识点熟悉一遍. ...
随机推荐
- volatile特性及内存语义
1.volatile变量自身具有下列特性:·可见性:对一个volatile变量的读,总是能看到(任意线程)对这个volatile变量最后的写入.·原子性:对任意单个volatile变量的读/写具有原子 ...
- P1144 最短路计数
P1144 最短路计数 题目描述 给出一个N个顶点M条边的无向无权图,顶点编号为1-N.问从顶点1开始,到其他每个点的最短路有几条. 输入输出格式 输入格式: 输入第一行包含2个正整数N,M,为图的顶 ...
- 推荐一款强大的3D家装开源软件
2015年家装o2o着实火了一把.家装涉及到上门量尺,再设计,这个过程是免不了的. 目前基于bs架构的酷家乐,爱福窝等,流行起来就是着力于这点,通过一个点寻找突破口,进入深度挖掘,带动其他家具等产品来 ...
- Intel系列微处理器的三种工作模式
body, table{font-family: 微软雅黑; font-size: 13.5pt} table{border-collapse: collapse; border: solid gra ...
- win7 mysql 数据库轻松实现数据库定时备份
本地备份: 第一步: 安装一个mysql. 第二步: 在命令行中配置mysql 打开环境变量将mysql 安装路径配置到path中 第三部: cmd 中输入:mysqldump -uroot -p12 ...
- spring使用c3p0报错
java.sql.SQLException: Connections could not be acquired from the underlying database! at com.mchang ...
- python_递归_斐波那契
什么是递归算法? -- 函数自己调用自己本身 -- 本质上return返回的时候,总是把一个参数传入到自己函数本身,让函数反复调用下去 递归有何特点? -- 必有一个结束条件 没有结束条件,递归就没有 ...
- 1 let和const
let命令 1)let声明的变量只在let命令所在的代码块内有效,如: { let a = ; ;} a // ReferenceError: a is not defined. b 对于for循 ...
- Hibernate (一)
1 JDBC的优缺点 优点: 直接底层操作,提供了简单.便捷的访问数据库的方法,跨平台比较强. 灵活性比较强,可以写复杂的SQL. 缺点: JDBC没有做到面向对象的编程,使得程序员的思考还停留在SQ ...
- ado.net 参数传递之 in
之前项目有一放行的功能,对某界面维护时(数据的增删改),先将数据保存到临时表中,放行后再真正的写入到库中.由于设计到主从表多中约束关系,所以当时我采用的是写一个存储过程来对某个界面的操作进行统一处理, ...