周孝未


私信TA

用户名:dotcpp0664574

访问量:1449

签 名:

等  级
排  名 1992
经  验 2517
参赛次数 1
文章发表 14
年  龄 0
在职情况 学生
学  校 淄博职业学院
专  业

  自我简介:

TA的其他文章

解题思路:
1.对题目需求进行逐条分析

2.将题目拆解为一个个可实现的小点,根据分析调用知识点,思考如何灵活运用相应的方法

3.写出大概代码后,将进行详细调优

(化繁为简,先死后活)
注意事项:
1.注意全局变量和局部变量的设计

提示:

scanner.close()方法来关闭Scanner对象。

这是为了释放与该Scanner对象关联的资源,并且可以防止可能的资源泄漏。

参考代码:


import java.util.Scanner;//导包

public class ScholarshipTest {
   public static void main(String[] args) {
       Scanner scanner = new Scanner(System.in);
       int N = scanner.nextInt(); // 学生总数

       String maxName = ""; // 获得最多奖金的学生姓名
       int maxBonus = 0; // 最多奖金数
       int totalBonus = 0; // 所有学生的奖学金总数

       for (int i = 0; i < N; i++) {
           String name = scanner.next(); // 学生姓名
           int averageScore = scanner.nextInt(); // 期末平均成绩
           int reviewScore = scanner.nextInt(); // 班级评议成绩
           char isCadre = scanner.next().charAt(0); // 是否是学生干部
           char isWestern = scanner.next().charAt(0); // 是否是西部省份学生
           int papers = scanner.nextInt(); // 发表的论文数

           int bonus = 0; // 学生的奖学金总数
           if (averageScore > 80 && papers >= 1) {
               bonus += 8000; // 院士奖学金
           }
           if (averageScore > 85 && reviewScore > 80) {
               bonus += 4000; // 五四奖学金
           }
           if (averageScore > 90) {
               bonus += 2000; // 成绩优秀奖
           }
           if (averageScore > 85 && isWestern == 'Y') {
               bonus += 1000; // 西部奖学金
           }
           if (reviewScore > 80 && isCadre == 'Y') {
               bonus += 850; // 班级贡献奖
           }

           totalBonus += bonus; // 更新奖学金总数

           if (bonus > maxBonus) {
               maxBonus = bonus; // 更新最多奖金数
               maxName = name; // 更新最多奖金学生的姓名
           }
       }

       System.out.println(maxName); // 输出获得最多奖金的学生的姓名
       System.out.println(maxBonus); // 输出该学生获得的奖金总数
       System.out.println(totalBonus); // 输出所有学生的奖学金总数

       scanner.close();
   }
}


 

0.0分

5 人评分

  评论区

  • «
  • »