做了一个小型的成绩管理系统。主要代码如下:

/*
 * 功能:简易学生成绩管理系统
 */
package day7;

import java.util.Scanner;

public class HomeWork {
 static Scanner scan=new Scanner(System.in);
 static String[] user=new String[2];
 static String[] password=new String[2];
 static String[] name=new String[5];
 static int[] score=new int[name.length];
 static boolean c=false;
 public static void main(String[] args) {

fun();
 }
 public static void fun(){
  while(true){
  System.out.println("欢迎使用简易成绩管理系统0.0");
  System.out.println("A注册");
  System.out.println("B登录");
  System.out.println("C退出");

char str=scan.next().charAt(0);
  switch(str){
  case 'A':
   register(user,password);
   break;
  case 'B':
   login(user,password);
   break;
  case 'C':
   System.out.println("退出成功!!!");
   System.exit(0);
   break;
  default :
   System.out.println("输入有误,请重新输入。");
  }
  }
 
 }
 public static void register(String user[],String password[]){
  for (int i = 0; i < user.length; i++) {
   if(user[i]==null){System.out.println("请输入用户名:");
   user[i]=scan.next();
   System.out.println("请输入密码:");
   password[i]=scan.next();
   System.out.println("注册成功,返回登录!!!");
   fun();
   }

}
  System.out.println("用户已经达到上限,请联系管理员。");
  
  }
 
 public static void login(String user[],String password[]){
  System.out.println("请输入用户名");
  String str1=scan.next();
  System.out.println("请输入密码:");
  String str2=scan.next();
  for (int i = 0; i < user.length; i++) {
   if(str1.equals(user[i])&&str2.equals(password[i])){
    System.out.println("登录成功!!!欢迎您!!!");
    fun1();
   }else{
    System.out.println("没找到该用户!请重新登录");
    fun();
   }
  }
  
 }
 public static void fun1(){
  System.out.println("A增加学生分数信息");
  System.out.println("B修改学生分数信息");
  System.out.println("C删除学生分数信息");
  System.out.println("D查询学生信息");
  System.out.println("E返回上级菜单");
  char str=scan.next().charAt(0);
  switch(str){
  case 'A':
   add(name,score);
   break;
  case 'B':
   modify(name,score);
   break;
  case 'C':
   delete(name,score);
   break;
  case 'D':
   insert(name,score);
   break;
  case 'E':
   fun();
   break;
  }
  
 }
 public static void add(String[] name,int[] score){
  for (int i = 0; i < name.length; i++) {
   System.out.println("请输入第"+(i+1)+"个学生的名字:");
   name[i]=scan.next();
   System.out.println("请输入第"+(i+1)+"个学生的分数:");
   score[i]=scan.nextInt();
  }
  System.out.println("新增学生信息成功!!!返回上级菜单");
  fun1();
 }
 public static void delete(String[] name,int[] score){
  System.out.println("请输入你要删除的学生姓名:");
  String str=scan.next();   
  if(name[0].equals(str)){
   System.out.println("成功删除了"+name[0]+"的信息");
   for (int j = 0; j < name.length; j++) {
    name[j]=name[j+1];
    score[j]=score[j+1];
    c=true;
    }
   }
  if(name[name.length-1].equals(str)){
   System.out.println("成功删除了"+name[name.length-1]+"的信息");
   name[name.length-1]=null;
   score[score.length-1]=0;
   c=true;
  }
  for (int i = 1; i < name.length; i++) {

if(name[i-1].equals(str)){
    System.out.println("成功删除了"+name[i-1]+"的信息");
    name[i-1]=name[i];
    score[i-1]=score[i];
    c=true;
   }    
   }
  if(c){
   name[name.length-1]=null;
   score[score.length-1]=0;
   fun1();
  }else{
  System.out.println("没有找到该学的信息");
  fun1();
  }
  }
 public static void modify(String[] name,int[] score){
  System.out.println("请输入你要修改的学生姓名:");
  String str=scan.next();
  for (int i = 0; i < name.length; i++) {
   if(name[i].equals(str)){
    System.out.println("你要修改的是"+name[i]+"的分数,请输入你要修改的分数:");
    score[i]=scan.nextInt();
    System.out.println("修改成功!!!返回上级菜单");
    fun1();
   }else{
    System.out.println("没有找到该学的信息");
   }
  }
  
 }
 public static void insert(String[] name1,int[] score1){
  System.out.println("A查询一个学生分数:");
  System.out.println("B查询所有学生分数:");
  char str=scan.next().charAt(0);
  switch(str){
  case 'A':
   System.out.println("请输入查询的学生姓名:");
   String str1=scan.next();
   for (int i = 0; i < name1.length; i++) {
    if(name[i].equals(str1)){
     System.out.println("你查询的是"+name1[i]+"的分数,他的分数是:"+score1[i]);
     fun1();
    }
   }
   System.out.println("没有找到该学生的信息!!!");
   break;
  case 'B':
   for (int i = 0; i < name1.length; i++) {
    System.out.println(name1[i]+"的分数是:"+score1[i]);
   }
   break;
  }
  fun1();
 }
}

day7 方法及基础知识运用的更多相关文章

  1. 链方法[C# 基础知识系列]专题三:如何用委托包装多个方法——委托链

    最近研究链方法,稍微总结一下,以后继续补充: 弁言: 上一专题分析了下编译器是如何来翻译委托的,从中间语言的角度去看委托,希望可以帮助大家进一步的理解委托,然而之前的分析都是委托只是封装一个方法,那委 ...

  2. Nand Flash基础知识与坏块管理机制的研究

    概述 Flash名称的由来,Flash的擦除操作是以block块为单位的,与此相对应的是其他很多存储设备,是以bit位为最小读取/写入的单位,Flash是一次性地擦除整个块:在发送一个擦除命令后,一次 ...

  3. Object&nbsp;c&nbsp;基础知识

    文件类型说明:.h 头文件,用于定义类.实例变量及类中的方法等定义信息(interface). .m 源文件,定义方法体,可实现objce-c和c方法(implementation). .mm c++ ...

  4. js基础知识温习:Javascript中如何模拟私有方法

    本文涉及的主题虽然很基础,在很多人眼里属于小伎俩,但在JavaScript基础知识中属于一个综合性的话题.这里会涉及到对象属性的封装.原型.构造函数.闭包以及立即执行表达式等知识. 公有方法 公有方法 ...

  5. java基础知识回顾之---java String final类普通方法

    辞职了,最近一段时间在找工作,把在大二的时候学习java基础知识回顾下,拿出来跟大家分享,如果有问题,欢迎大家的指正. /*     * 按照面向对象的思想对字符串进行功能分类.     *      ...

  6. C#基础知识学习(1)方法的重写和隐藏

    做了1年多了C#,发现些项目过程中很多基础东西都不是很清晰,基础不够牢固.现在开始复习基础知识并做重点记录 方法需要被重写的时候,可以在方法前加入virtual使方法变成虚方法. 这样我们可以重新写个 ...

  7. Python入门方法推荐,哪些基础知识必学?

    很多想入门的小伙伴还不知道Python应该怎么学,哪些知识必学,今天我们就来盘点一下. 01.入门方法推荐 总体来讲,找一本靠谱的书,由浅入深,边看边练. 网上的学习教程有很多,多到不知道如何选择.所 ...

  8. 数据结构和算法(Golang实现)(10)基础知识-算法复杂度主方法

    算法复杂度主方法 有时候,我们要评估一个算法的复杂度,但是算法被分散为几个递归的子问题,这样评估起来很难,有一个数学公式可以很快地评估出来. 一.复杂度主方法 主方法,也可以叫主定理.对于那些用分治法 ...

  9. .NET面试题系列[1] - .NET框架基础知识(1)

    很明显,CLS是CTS的一个子集,而且是最小的子集. - 张子阳 .NET框架基础知识(1) 参考资料: http://www.tracefact.net/CLR-and-Framework/DotN ...

随机推荐

  1. 20162328蔡文琛 week05 大二

    20162328 2017-2018-1 <程序设计与数据结构>第5周学习总结 教材学习内容总结 集合是收集元素并组织其他对象的对象. 集合中的元素一般由加入集合的次序或元素之间的某些固有 ...

  2. 用java进行简单的万年历编写

    import java.util.Scanner; public class PrintCalendarDemo1 { public static void main(String[] args) { ...

  3. 对Largest函数的测试

    题目:查找list[]中的最大值:int Largest(int list[], int length); int Largest(int list[], int length) { int i,ma ...

  4. 安装AndroidJDK的坑

    最近公司要用weex了,先开始搭一下环境,真的都是坑,写下来大家引以为鉴,我踩坑三天的后果. 首先要安装JavaJDK这个过程就不写了都是程序员网上搜索一下很多,注意找论坛上最新的帖子来看,这里有一个 ...

  5. 编程之法section II: 2.1 求最小的k个数

    ====数组篇==== 2.1 求最小的k个数: 题目描述:有n个整数,请找出其中最小的k个数,要求时间复杂度尽可能低. 解法一: 思路:快排后输出前k个元素,O(nlogn). writer: zz ...

  6. 四则运算App--大总结(已完成)

    1. 贡献分分配(20分) 欧泽波:14分,Android的学习,代码的编写,等等 杨洁华:1分,提供学习资料,框架的设计等等 赵泽嘉:3分,提供学习资料,框架的设计等等 林扬滨:2分,提供学习资料, ...

  7. 【Python】LeetCode-155

    一.题目 Design a stack that supports push, pop, top, and retrieving the minimum element in constant tim ...

  8. 【搜索】POJ-3669 BFS

    一.题目 Description Bessie hears that an extraordinary meteor shower is coming; reports say that these ...

  9. Http的响应结构

    Http响应结构有三部分组成: Http头部(Http Header):它们包含了更多关于响应的信息.比如:头部可以指定认为响应过期的过期日期,或者是指定用来给用户安全的传输实体内容的编码格式.如何在 ...

  10. 交换机、linux光衰查询

    RX收光,TX发光 一.交换机 命令: display interface transceiver brief 结果: ...... HW6851 10GE1/0/15 transceiver dia ...