Java day 04丶28

第五天:数组、方法和字符串###

  1. 一维数组

定义数组的语法:

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;
		}
	}
}

  1. 二维数组

练习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];
                          int[] sum  =  new  int[stuNames.length];
		         int[] max  =  new  int[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();
                                sum[i] += scores[i][j];
			}
		}
		
		for(int i = 0; i<subNames.length; ++i) {
			for( int j = 0; j < stuNames.length; ++j) {
				max[i] += scores[j][i];
			}
		}
		
		for(int i = 0; i < stuNames.length; ++i) {
			System.out.println(stuNames[i] + "的平均成绩为:" + sum[i]/3);
		}
		
		System.out.println();
		
		for(int i = 0; i < subNames.length; ++i) {
			System.out.println(subNames[i] + "科目的平均成绩为:" + max[i]/5);
		}

	      

		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();
		}
	}
}
  1. 方法的定义和使用
  2. 方法的递归调用
  3. 字符串用法及常用方法
posted @ 2015-04-28 21:01  悲伤丶才说爱  阅读(94)  评论(0编辑  收藏  举报