ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

Java对象数组之对象数组题目Student类

2021-01-16 17:32:21  阅读:144  来源: 互联网

标签:Java 数组 int stu state score Student public


问题描述

定义类Student,包含三个属性:学号number(int),年级state(int) ,成绩score(int)。创建20个学生对象,学号为1到20号,年级和成绩都由随机数确定。
问题1:打印出3年级(state值为3)的学生信息。
问题2:使用冒泡排序按学生成绩排序,并遍历所有学生信息。

创建Student类:

public class Student {
	
      int number;  //学号
      int state;   //年级
      int score;   //成绩
	public int getNumber() {
		return number;
	}
	public void setNumber(int number) {
		this.number = number;
	}
	public int getState() {
		return state;
	}
	public void setState(int state) {
		this.state = state;
	}
	public int getScore() {
		return score;
	}
	public void setScore(int score) {
		this.score = score;
	}
	
	public String info() {  //显示学生信息
		return ("学号:"+this.number+",年级"+this.state+",成绩"+this.score);
		
	}
        	
	}
	

创建类Stu_test:

    
import java.lang.Math;
public class Stu_test {
	        public static void main(String [] args) {
	        	
	        	Student[] stu = new Student[20];  //创建20个学生对象
	        	Stu_test test =  new Stu_test();  //创建类对象调用封装的方法
        	for(int i=0;i<stu.length;i++) {  //数组元素赋值
	        		stu[i] = new Student();
		        	stu[i].number=(i+1);
		        	stu[i].state = (int)(Math.random()*(6-1+1)+1);  //年级[1,6]
		        	stu[i].score = (int)(Math.random()*(100-0+1));  //成绩[0,100]
             
	        	}
	        
          
        	System.out.println("************问题一************");//问题一
           test.Print(stu);
           test.search(stu, 3);
	     
	       
	       System.out.println("*************问题二***********");  //问题一
           
	       //使用冒泡排序按学生成绩排序并遍历学生信息
	       test.Order(stu);
	       test.Print(stu);
	   
	      
	}
	        
	        //將方法進行封裝  
	        public void search(Student stu[],int state) {
		   		for(int j=0;j<20;j++) {  //打印3年级的学生信
		      		 System.out.println();
		      		if (stu[j].state==3) {
		          	System.out.println(stu[j].info());
		   			}
		      		
		      	}
		    }
	        
	    	public void Order (Student[] stu) {
	    	    //使用冒泡排序按学生成绩排序并遍历学生信息
	    	       for(int i = 0; i<stu.length-1;i++) {
	    	    	   for(int j=0;j<stu.length-1-i;j++) {
	    	    		   if(stu[j].score>=stu[j+1].score) {
	    	    			   Student temp = stu[j];  
	    	    			   // 交换的是学生这个对象而不是交换他们的成绩
	    	    			   stu[j]=stu[j+1];
	    	    			   stu[j+1]=temp;
	    	    		   }
	    	    	   }
	    	       }
	    	   
	    	}
	    	
	    	public void Print(Student[] stu) {  //遍历学生信息
	    		for(int j=0;j<20;j++) {  //打印所有年级的学生信息
	            	System.out.println(stu[j].info());
	    			}
	    	}
	    		
	        
}

标签:Java,数组,int,stu,state,score,Student,public
来源: https://blog.csdn.net/weixin_43553142/article/details/112716442

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有