Java知识(006)--数组
来源:互联网 发布:eview触摸屏软件 编辑:程序博客网 时间:2024/05/22 13:15
- 一维数组
定义数组的语法:
T[] x = new T[size];T[] y = { value1, value2, ... };
- 操作数组元素可以使用下标运算[ ],数组的下标范围0-(数组大小-1)。
- 数组有一个length属性表示数组元素的个数。
- 通常可以用循环来对数组中的元素进行操作。
练习1:录入5名学生的成绩,计算平均分,找出最高分和最低分。
package com.lovoinfo;import java.util.Scanner;public class Test01 { public static void main(String[] args) { Scanner sc = new Scanner(System.in); String[] names = {"关羽", "张飞", "赵云", "黄忠", "马超"}; double[] scores = new double[5]; double sum = 0; for(int i = 0; i < scores.length; i++) { System.out.print("请输入" + names[i] + "的成绩: "); scores[i] = sc.nextDouble(); sum = sum + scores[i]; } System.out.println("平均分为: " + sum / scores.length); int maxIndex = 0, minIndex = 0; for(int i = 1; i < scores.length; i++) { if(scores[i] > scores[maxIndex]) { maxIndex = i; } else if(scores[i] < scores[minIndex]) { minIndex = i; } } System.out.println(names[maxIndex] + "考了最高分" + scores[maxIndex]); System.out.println(names[minIndex] + "考了最低分" + scores[minIndex]); sc.close(); }}
练习2:输出前20个Fibonacci数。
1, 1, 2, 3, 5, 8, 13, 21, 34, …
package com.lovoinfo;/** * 输出前20个Fibonacci数 * @author jackfrued * */public class Test04 { public static void main(String[] args) { int[] f = new int[20]; f[0] = f[1] = 1; for(int i = 2; i < f.length; i++) { f[i] = f[i - 1] + f[i - 2]; } for(int x : f) { System.out.println(x); } }}
练习3:随机产生10个数,并对其进行排序。
package com.lovoinfo;public class Test05 { public static void main(String[] args) { int[] a = new int[10]; System.out.println("排序前: "); for (int i = 0; i < a.length; i++) { a[i] = (int) (Math.random() * 100); System.out.print(a[i] + "\t"); } bubbleSort(a); System.out.println("\n排序后: "); for (int x : a) { System.out.print(x + "\t"); } } /** * 冒泡排序 * @param a 待排序的数组 */ public static void bubbleSort(int[] a) { // N个元素排序需要N-1趟循环 for (int i = 0; i < a.length - 1; i++) { // 相邻元素两两比较 for(int j = 0; j < a.length - 1 - i; j++) { if(a[j] > a[j + 1]) { // 如果前面元素大于后面元素就交换 int temp = a[j]; a[j] = a[j + 1]; a[j + 1] = temp; } } } } /** * 简单选择排序 * @param a 待排序的数组 */ public static void selectionSort(int[] a) { for (int i = 0; i < a.length - 1; i++) { int minIndex = i; // 假设当前的i是最小元素所在的位置 for (int j = i + 1; j < a.length; j++) { if (a[j] < a[minIndex]) { // 发现更小的元素 minIndex = j; // 记录更小的元素所在的位置 } } // 将i位置上的元素和最小元素交换位置 int temp = a[i]; a[i] = a[minIndex]; a[minIndex] = temp; } }}
- 二维数组
练习4:输入5个学生三门课的成绩,计算每个学生的平均分以及每门课程的平均分。
package com.lovoinfo;import java.util.Scanner;public class Test07 { public static void main(String[] args) { Scanner sc = new Scanner(System.in); String[] stuNames = {"关羽", "张飞", "赵云", "黄忠", "马超"}; String[] subNames = {"语文", "数学", "英语"}; int[][] scores = new int[stuNames.length][subNames.length]; for(int i = 0; i < scores.length; i++) { System.out.println("请录入" + stuNames[i] + "的成绩"); for(int j = 0; j < scores[i].length; j++) { System.out.print("\t" + subNames[j] + ": "); scores[i][j] = sc.nextInt(); } } sc.close(); }}以下不会
练习5:输出10行杨辉三角。
package com.lovoinfo;/** * 杨辉三角 * @author jackfrued * */public class Test08 { public static void main(String[] args) { int[][] y = new int[10][]; for(int i = 0; i < y.length; i++) { y[i] = new int[i + 1]; for(int j = 0; j < y[i].length; j++) { if(j == 0 || j == i) { y[i][j] = 1; } else { y[i][j] = y[i - 1][j] + y[i - 1][j - 1]; } } } for(int[] a : y) { for(int b : a) { System.out.print(b + "\t"); } System.out.println(); } }}
0 0
- Java知识(006)--数组
- Java知识(数组)
- Java知识(007)--数组题练习
- Java数组知识详解
- Java知识总结-数组
- Java数组知识详解
- 关于java数组知识
- java数组知识
- java的数组知识
- Java知识---数组
- java学习(5) java 数组相关知识
- JAVA知识碎片整理-----数组
- java之数组小知识
- Java知识碎片整理(1)——数组相关
- Java之数组小知识(加内存图)
- java 自我知识总结(八)数组的复制
- Java数组的的一些知识
- java语句及数组知识总结
- android中EditText插入用户名(块)效果(EditText插入图片)
- [漏洞分析] BEdita CMS 3.5.0中存储型XSS与CSRF漏洞分析
- 2754: C++习题-快速排序
- 在main()之前,IAR都做了些什么工作
- 《佐贺的超级阿嬷》读后感
- Java知识(006)--数组
- 黑马程序员—【Java高新技术】之反射
- 关于myeclipse 连接 sql server
- Cell中实现高效的下载图片及强大的SDWebImage(2015428)
- poj2442 堆
- 安卓中关于点击响应事件的四种写法(电话拨号器)
- [LeetCode]-006-ZigZag Conversion
- 第五天:数组、方法和字符串day0428
- asp.net中Response.write与Response.Redirect同时使用