1.随机点名器案例

1.1      案例介绍

随机点名器,即在全班同学中随机的找出一名同学,打印这名同学的个人信息。

此案例在我们昨天课程学习中,已经介绍,现在我们要做的是对原有的案例进行升级,使用新的技术来实现。

我们来完成随机点名器,它具备以下3个内容:

l  存储所有同学姓名

l  总览全班同学姓名

l  随机点名其中一人,打印到控制台

1.2      案例需求分析

全班同学中随机的找出一名同学,打印这名同学的个人信息。

我们对本案例进行分析,得出如下分析结果:

1.存储全班同学信息(姓名、年龄)

2.打印全班同学每一个人的信息(姓名、年龄)

3.在班级总人数范围内,随机产生一个随机数,查找该随机数所对应的同学信息(姓名、年龄)

随机点名器明确地分为了三个功能。如果将多个独立功能的代码写到一起,则代码相对冗长,我们可以针对不同的功能可以将其封装到一个方法中,将完整独立的功能分离出来。

而在存储同学姓名时,如果对每一个同学都定义一个变量进行姓名存储,则会出现过多孤立的变量,很难一次性将全部数据持有。此时,我们采用ArrayList集合来解决多个学生信息的存储问题。

package com.oracle.linkedlist;

public class Student {

String name;

int age;

}

package com.oracle.linkedlist;

import java.util.Scanner;

import java.util.Random;

class Test04 {

public static void main(String[] args) {

String[] arr=new String[5];

//  存储所有同学姓名

StudentName(arr);

//  总览全班同学姓名

StudentCname(arr);

//  存储所有同学姓名

StudentSname(arr);

}

//  存储所有同学姓名

public static void StudentName(String[] arr){

Scanner sc=new Scanner(System.in);

for (int i=0;i<arr.length;i++) {

System.out.println("第"+(i+1)+"同学姓名");

arr[i]=sc.next();

}

}

//  总览全班同学姓名

public static void StudentCname(String[] arr){

for(int i=0;i<arr.length;i++){

System.out.println("第"+(i+1)+"个同学:"+arr[i]);

}

}

//  存储所有同学姓名

public static void StudentSname(String[]arr){

int a = new Random().nextInt(arr.length);

System.out.println("被点到名的同学是:" +arr[a]);

}

}

运行结果:

2.库存管理案例

2.1      案例介绍

现在,我们将原有的库存管理案例,采用更好的集合方式实现。

将对下列功能进行方法封装:

l  打印库存清单功能

l  库存商品数量修改功能

l  退出程序功能

2.2  案例需求分析

管理员能够进行的操作有3项(查看、修改、退出),我们可以采用(switch)菜单的方式来完成。

-------------库存管理------------

1.查看库存清单

2.修改商品库存数量

3.退出

请输入要执行的操作序号:

每一项功能操作,我们采用方法进行封装,这样,可使程序的可读性增强。

选择“1.查看库存清单”功能,则控制台打印库存清单

选择“2.修改商品库存数量”功能,则对每种商品库存数进行更新

选择“3.退出”功能,则退出库存管理,程序结束

package com.oracle.demo03;

public class Stores {
    
    String sname;
    double ssize;
    double smoney;
    int sinventory;
    
}

package com.oracle.demo03;

import java.util.ArrayList;
import java.util.Scanner;

public class store {

public static void main(String[] args) {
        
        ArrayList<Stores> list=new ArrayList();
        Scanner sc=new Scanner(System.in);
        while(true){
        
            MainMenu();
            
            int num=sc.nextInt();
            switch(num){
            
            case 1:QueryStore(list);
                break;
                
            case 2:updateStore(list);
                break;
                
            case 3:addStore(list);
                break;
                
            case 4:delectStore(list);
                break;
                
            case 5:
                return;
                
            default:
                break;
            }
        
        }

}

//主菜单
    public static void MainMenu(){
        
        System.out.println("----------库存管理-----------");
        System.out.println("1.查看库存清单");
        System.out.println("2.修改商品库存数量");
        System.out.println("3.添加商品");
        System.out.println("4.删除商品");
        System.out.println("5.退出");
        System.out.println("请输入您要执行的编号:");
    }
    
    //查看库存清单
    public static void QueryStore(ArrayList<Stores> list){
        
        System.out.println("---------商城库存清单----------");
        System.out.println("品牌型号\t\t尺寸\t价格\t库存数");
        //MacBookAir品牌
        Stores s1=new Stores();
        s1.sname="MacBookAir";
        s1.ssize=13.3;
        s1.smoney=6988.88;
        s1.sinventory=5;
        System.out.println(s1.sname+"\t"+s1.ssize+"\t"+s1.smoney+"\t"+s1.sinventory);
        
        //ThinkpadT450品牌
        Stores s2=new Stores();
        s2.sname="ThinkpadT450";
        s2.ssize=14.0;
        s2.smoney=5999.99;
        s2.sinventory=10;
        System.out.println(s2.sname+"\t"+s2.ssize+"\t"+s2.smoney+"\t"+s2.sinventory);
        
        //ASUS-FL5800品牌
        Stores s3=new Stores();
        s3.sname="ASUS-FL5800";
        s3.ssize=15.6;
        s3.smoney=4999.5;
        s3.sinventory=18;
        System.out.println(s3.sname+"\t"+s3.ssize+"\t"+s3.smoney+"\t"+s3.sinventory);
            
        //总库存数
        int sum=s1.sinventory+s2.sinventory+s3.sinventory;
        //库存商品总金额
        double SUM=s1.smoney*5+s2.smoney*10+s3.smoney*18;
        
        
        
        for(int i=0;i<list.size();i++){
            
            System.out.println(list.get(i).sname+"\t\t"+list.get(i).ssize+"\t"+list.get(i).smoney+"\t"+list.get(i).sinventory);
            
        }
        System.out.println("---------------------------");
        System.out.println("总库存数:"+sum);
        System.out.println("库存商品总金额:"+SUM);
        
        
        
    }
    //修改商品数量
    public static void updateStore(ArrayList<Stores> list){
        
        QueryStore(list);
        Scanner sc=new Scanner(System.in);
        System.out.println("请输入要修改的品牌数量:");
        int inventory=sc.nextInt();
        Stores stores=new Stores();
        stores.sinventory=inventory;
        for(int i=0;i<list.size();i++){
            
            if(inventory==list.get(i).sinventory){
                list.set(i, stores);
            }
            
        }
        
        
        
        
    }
    //添加清单
    public static void addStore(ArrayList<Stores> list){
        
        Scanner sc=new Scanner(System.in);
        Stores stores=new Stores();
        System.out.println("请输入新增加的品牌型号:");
        String name=sc.next();
        System.out.println("请输入新增加的品牌尺寸:");
        double size=sc.nextDouble();
        System.out.println("请输入新增加的品牌价格:");
        double money=sc.nextDouble();
        System.out.println("请输入新增加的品牌库存数:");
        int inventory=sc.nextInt();
        stores.sname=name;
        stores.ssize=size;
        stores.smoney=money;
        stores.sinventory=inventory;
        list.add(stores);
        System.out.println("添加商品成功!");
        
        
    }
    
    
    //删除清单
    public static void delectStore(ArrayList<Stores> list){
        
        QueryStore(list);
        Scanner sc=new Scanner(System.in);
        System.out.println("请输入您要删除的品牌名称:");
        String num=sc.next();
        for(int i=0;i<list.size();i++){
            
            if(num==list.get(i).sname){
                
                list.remove(i);
            }
            System.out.println("删除商品成功!");
        }
        
    }
}

运行结果:

Java案例整理的更多相关文章

  1. Java validator整理

    Java validator整理 因为想对方法的入参和出参作简单的非空或者非空字符做校验,所以找了下相关的@NotNull注解 类 | 说明 --- | --- javax.validation.co ...

  2. _00019 Storm架构介绍和Storm获取案例(简单的官方网站Java案例)

    博文作者:妳那伊抹微笑 itdog8 地址链接 : http://www.itdog8.com(个人链接) 博客地址:http://blog.csdn.net/u012185296 博文标题:_000 ...

  3. java笔记整理

    Java 笔记整理 包含内容     Unix Java 基础, 数据库(Oracle jdbc Hibernate pl/sql), web, JSP, Struts, Ajax Spring, E ...

  4. Java资料整理

    Java资料整理 原创 2017年08月25日 17:20:44 14211  1.LocalThread的应用场景,数据传输适合用LocalThread么 2.linux的基本命令    软链接.更 ...

  5. ETL工具之kittle使用案例整理

    主花了一下午时间,收集全网,学习了下kittle,觉得该大v写的不错,特意整理给大家!学会这几个案例kittle基本就没问题了. 1.kettle案例一抽取gz格式文本内容保存到mongodb  ht ...

  6. JAVA基础整理-集合篇(一)

    集合作为JAVA的基础知识,本来感觉自己理解的很清楚了,但是在最近的一次面试中还是答得不尽如人意!再次做一下整理,以便加深理解以及随时查阅. 首先,java.util包中三个重要的接口及特点:List ...

  7. Java数据结构整理(一)

    ava数据结构内容整理关键字: 数据结构 Collection:List.SetMap:HashMap.HashTable如何在它们之间选择一.Array , ArraysJava所有“存储及随机访问 ...

  8. 面试之Java知识整理

    1.面向对象都有哪些特性 继承.封装.多态性.抽象 2.Java中实现多态的机制是什么? 继承与接口 3.Java中异常分为哪些种类 3.1按照异常需要处理的时机分为编译时异常(CheckedExce ...

  9. Java案例:双色球的实现

    //随机生成双色球号码 //案例:6颗红球(33选1)  1颗蓝球(16选1) 代码实现如下: import java.util.Random; import java.util.Arrays; // ...

随机推荐

  1. 【bzoj1150】[CTSC2007]数据备份Backup 模拟费用流+链表+堆

    题目描述 你在一家 IT 公司为大型写字楼或办公楼(offices)的计算机数据做备份.然而数据备份的工作是枯燥乏味的,因此你想设计一个系统让不同的办公楼彼此之间互相备份,而你则坐在家中尽享计算机游戏 ...

  2. CABAC总结与补充讨论

    在之前的一篇文章CABAC中我们已经对算法中的大部分细节部分做了详细分析,这里做一个总结与拾遗. 总结 CABAC的编码可以分为以下四个部分: 上下文变量的初始化 待编码语法元素二值化 上下文建模(确 ...

  3. 【C/C++】实现数据结构广义表

    1. 广义表的定义     每个元素可以为Atom,原子,也可以为线性表.      线性表的推广.线性表元素有唯一的前驱和后继,为线性表,而广义表是多层次的线性表      表头:第一个元素,可能是 ...

  4. 双系统windows+linux如何正确删除linux

    双系统windows+linux如何正确删除linux 2017年11月16日 10:42:49 dovepym 阅读数:26363   之前在windows的基础上又安装了ubuntu系统16.04 ...

  5. Django框架中的Context使用

    Django框架中的Context使用 2017年11月09日 20:01:09 aweilark 阅读数:1113   转载自:http://www.aichengxu.com/python/606 ...

  6. luogu P1816 【忠诚】

    话说许多dalao都采取线段树A题可本蒟蒻不会啊, 暴力的我想出了暴力解法(快排) #include<cstdio> #include<algorithm> using nam ...

  7. Codeforces Round #437 Div. 1

    A:显然构造一组只包含1和2面值的数据即可. #include<iostream> #include<cstdio> #include<cmath> #includ ...

  8. Docker基本使用(二)

    Docker 客户端 我们可以直接输入 docker 命令来查看到 Docker 客户端的所有命令选项. 可以通过命令 docker command --help 更深入的了解指定的 Docker 命 ...

  9. vscode跳转到函数定义处

    需要安装对应语言的插件,帮助-欢迎使用,安装javascript, php php还需要安装php7, 到官网https://windows.php.net/download#php-7.2 下载解压 ...

  10. 【BZOJ5469】[FJOI2018]领导集团问题(动态规划,线段树合并)

    [BZOJ5469][FJOI2018]领导集团问题(动态规划,线段树合并) 题面 BZOJ 洛谷 题解 题目就是让你在树上找一个最大的点集,使得两个点如果存在祖先关系,那么就要满足祖先的权值要小于等 ...