java基础:3.2 多维数组

1.申明

int [][] array1 ={  {1,2,3} , {0} , {2,2,2,2,2} , {5,6} };  锯齿数组

int [][] array2 = new int [5][ ];    // new int[5][] 创建数组时,必须指定第一个下标标。语法new int[] []是错误的

array2[0] = new int[3];

array2[1] = new int[6];   ...

2.二维数组的长度

int [][] x =new int [3][4];

x.length = 3 ; 

x[0].length = x[1].length = x[2].length =4;

 

例子:选择题测验得分。用随机函数生成N个同学的选择题答案,保存在二维数组里。再随机生成一个正确答案,计算每位同学的正确率。

package basic_practice_003;

public class N_array { //多选题测验评分例子
	final static int countIssue = 9;
	final static int countStudent = 6;
	
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		
		System.out.println("       题目               :1 2 3 4 5 6 7 8 9");
		char [][]student = new char[countStudent][countIssue];	
		char []rightAnswer = new char[countIssue];
		getAnswer(rightAnswer);
		getAnswer(student,rightAnswer);

		
			
	}
	
	public static void getAnswer(char [][]m,char []rightAnswer){
		for(int j=0;j<countStudent;j++) {
			System.out.print("student " + j + ":");
			for(int i=0;i<countIssue;i++) {
				m[j][i]=getRandomAnswer();
				System.out.print(m[j][i] + " ");
				}
			int right =0;
			for(int i=0;i<countIssue;i++){
				if(m[j][i]==rightAnswer[i]) right++;
			}
			System.out.printf("   right rate = %.3f",right*1.0/countIssue);
			System.out.println();
		}		
	}
	public static void getAnswer(char []m){
		System.out.print("rightAns :");
			for(int i=0;i<countIssue;i++) {
				m[i]=getRandomAnswer();		
				System.out.print(m[i] + " ");}
			System.out.println();
	}
	
	public static char getRandomAnswer(){
		return(char)('A' + Math.random()*('D' - 'A' + 1));}
	

}

结果:

输入N点坐标点,找出距离最小的两点。

public class FindNearestPoints {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		System.out.println("1.enter the number of point:");
		Scanner input = new Scanner(System.in);
		int number_of_point = input.nextInt();
		System.out.println("2.enter " +2*number_of_point +" point:");
		double [][] point = new double[number_of_point][2];
		System.out.println("enter "+ number_of_point*2+" points location:");
		for(int i=0;i<number_of_point;i++) {
				point[i][0] = input.nextDouble();
				point[i][1] = input.nextDouble();
		}
	
		double nearestD = (point[0][0]-point[1][0])*(point[0][0]-point[1][0])+(point[0][1]-point[1][1])*(point[0][1]-point[1][1]);
		int index1=0,index2=0;
		for(int i=0;i<number_of_point;i++) {
			for(int j=i+1;j<number_of_point;j++) {
				double Distance = (point[i][0]-point[j][0])*(point[i][0]-point[j][0])+(point[i][1]-point[j][1])*(point[i][1]-point[j][1]);
				if(Distance < nearestD) {
					nearestD=Distance;
					index1=i;
					index2=j;
				}
			}
		}
		System.out.printf("the NearestPoints is (%.2f,%.2f),(%.2f,%.2f)",point[index1][0],point[index1][1],point[index2][0],point[index2][1] );
		System.out.println();
		System.out.println("the NearestD = " + Math.sqrt(nearestD));		
	}
}

posted @ 2018-12-26 21:56  Aurora_l  阅读(148)  评论(0编辑  收藏  举报