【Java刷题进阶】基础入门篇⑧

简介: 【Java刷题进阶】基础入门篇⑧

第一题:判断学生成绩


题目描述


定义一个方法用于录入学生的考试成绩,要求考试成绩必须在0-100之间,不满足就产生一个自定义异常,控制台输出一个错误信息"分数不合法"(请输出自定义异常对象的错误信息,将错误信息设置为分数不合法)

输入描述:

控制台输入的int类型整数

输出描述:

若分数合法则输出该分数,否则输出错误信息分数不合法

示例


输入: 100

输出: 100

输入:-1

输出: 分数不合法

题解


import java.util.*;
public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int score = scanner.nextInt();
        try{
            if(score >= 0 && score <= 100) //正常分数输出
                System.out.println(score);
            else
                throw new ScoreException("分数不合法"); //抛出异常
        }
        catch(ScoreException str){
            System.out.println(str.getMessage()); //输出异常
        }
    }
}
class ScoreException extends Exception{ //继承自异常类的分数异常处理类
    public ScoreException(String message){ //构造函数
        super(message); //输入异常信息
    }
}


第二题:字符串去重


题目描述


从键盘获取一串字符串,要求去除重复的字符。请使用HashSet解决这一问题

输入描述:

键盘输入的任意字符串

输出描述:

去重后的字符串(不要求顺序,预设代码中已经给出输出)

示例


输入: helloworld

输出: rdewhlo

题解


import java.util.HashSet;
import java.util.Scanner;
public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        String str = scanner.nextLine();
        scanner.close();
        HashSet<Character> hs = new HashSet<>();
        //write your code here......
//          新建HashSet,然后遍历字符串,将所有字符添加到Set。
//          由于HashSet本身结构不允许有重复的项,所以会自动去除重复的元素
        for(int i=0;i<str.length();i++){
            hs.add(str.charAt(i));
            //str.charAt (i)的意思是第i个字符在字符串str中所占的位置
            //不能直接使用str[i]这种方法来取字符串的值,这种取法只适合数组根据索引下标取值
        }
//         //第二种写法
//         //因为增强for循环只能够对数组进行循环,故我们应该先对str字符串进行toCharArray()将其数组化,进而取得其值
//         for(char c:str.toCharArray(){
//             hs.add(c);
//         }
        for (char c:hs) {
            System.out.print(c);
        }
    }
}


第三题:集合遍历


题目描述


请使用三种方式遍历一个list集合

输入描述:

键盘任意输入的五个int类型变量

输出描述:

使用三种不同的方法遍历集合,遍历输出时不换行,数字之间用空格隔开

示例


输入: 1 2 3 4 5

输出:

普通for循环:1 2 3 4 5

增强for循环:1 2 3 4 5

迭代器遍历:1 2 3 4 5

题解


import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.Scanner;
public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        List<Integer> list = new ArrayList<>();
        int num1 = scanner.nextInt();
        int num2 = scanner.nextInt();
        int num3 = scanner.nextInt();
        int num4 = scanner.nextInt();
        int num5 = scanner.nextInt();
        scanner.close();
        list.add(num1);
        list.add(num2);
        list.add(num3);
        list.add(num4);
        list.add(num5);
        System.out.print("普通for循环:");
        //write your code here......
        for(int i=0;i<list.size();i++){
            //泛型容器类的获取其长度用size
            //数组,字符串获取其长度用length
            //泛型容器类获取其值可以用get方法,数组则是用[]加下标的方法
            System.out.print(list.get(i)+" ");
        }
        System.out.println();
        System.out.print("增强for循环:");
        //write your code here......
        for(int i:list){
            System.out.print(i+" ");
        }
        System.out.println();
        System.out.print("迭代器遍历:");
        //write your code here......
//         int count = 0;
//         int i =0;
//         while(count<5){
//             System.out.print(list.get(i)+" ");
//             i++;
//             count++;
//         } 因题目要求使用迭代器循环,故舍弃该写法!
        //Iterator迭代器
        /**
            hasNext()方法:
            用来判断集合中是否有下一个元素可以迭代。如果返回true,说明可以迭代。
            Next()方法:
            用来返回迭代的下一个元素,并把指针向后移动一位。
        */
        //write new code
        Iterator it = list.iterator();
        while(it.hasNext()){
            System.out.print(it.next()+" ");
        }
        System.out.println();
    }
}


第四题:排队系统


题目描述


请设计一个排队程序,用户有普通客人和VIP客人之分,VIP客人不排队(即VIP客人在队列头部),目前队列中已有两位客人小明和小军在排队,请将VIP客人小红新增至队列头部。

输入描述:

输出描述:

预设代码中已经指定输出

题解


import java.util.*;
public class Main {
    public static void main(String[] args) {
        Guest guest1 = new Guest("小明",false);
        Guest guest2 = new Guest("小军",false);
        Guest vipGuest = new Guest("小红",true);
        Deque<Guest> deque = new ArrayDeque<>();
        deque.add(guest1);
        deque.add(guest2);
        deque.addFirst(vipGuest);
        System.out.println(deque);
    }
}
class Guest{
    String name;
    Boolean vip;
    @Override
    public String toString() {
        return name;
    }
    public Guest(String name, Boolean vip) {
        this.name = name;
        this.vip = vip;
    }
}


第五题:首尾交替出队


题目描述


现从一队学生中抽人上台演讲,为公平起见,队头队尾交替抽取,请通过程序实现这个出队的过程。

输入描述:

一组学生的名字

输出描述:

交替打印队头队尾学生的名字

示例


输入: Tom Jim Lily Lucy Mary

输出: Tom Mary Jim Lucy Lily

题解


import java.util.ArrayDeque;
import java.util.Scanner;
public class Main {
    public static void main(String[] args) {
        ArrayDeque deque = new ArrayDeque();
        Scanner scanner = new Scanner(System.in);
        while (scanner.hasNext()) {
            String name = scanner.next();
            // 初始化队列中的数据
            deque.offerLast(name);
        }
        // write your code here......
        int l = deque.size();
        for (int i=0; i<l; i++) {
            if (i%2==0) {
                System.out.println(deque.pollFirst());
            }
            else {
                System.out.println(deque.pollLast());
            }
        }
    }
}


目录
相关文章
|
1月前
|
存储 安全 Java
从入门到精通:Java Map全攻略,一篇文章就够了!
【10月更文挑战第17天】本文详细介绍了Java编程中Map的使用,涵盖Map的基本概念、创建、访问与修改、遍历方法、常用实现类(如HashMap、TreeMap、LinkedHashMap)及其特点,以及Map在多线程环境下的并发处理和性能优化技巧,适合初学者和进阶者学习。
50 3
|
12天前
|
监控 安全 Java
Java中的多线程编程:从入门到实践####
本文将深入浅出地探讨Java多线程编程的核心概念、应用场景及实践技巧。不同于传统的摘要形式,本文将以一个简短的代码示例作为开篇,直接展示多线程的魅力,随后再详细解析其背后的原理与实现方式,旨在帮助读者快速理解并掌握Java多线程编程的基本技能。 ```java // 简单的多线程示例:创建两个线程,分别打印不同的消息 public class SimpleMultithreading { public static void main(String[] args) { Thread thread1 = new Thread(() -> System.out.prin
|
18天前
|
Java 大数据 API
14天Java基础学习——第1天:Java入门和环境搭建
本文介绍了Java的基础知识,包括Java的简介、历史和应用领域。详细讲解了如何安装JDK并配置环境变量,以及如何使用IntelliJ IDEA创建和运行Java项目。通过示例代码“HelloWorld.java”,展示了从编写到运行的全过程。适合初学者快速入门Java编程。
|
24天前
|
存储 安全 Java
🌟Java零基础-反序列化:从入门到精通
【10月更文挑战第21天】本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
64 5
|
21天前
|
安全 Java 调度
Java中的多线程编程入门
【10月更文挑战第29天】在Java的世界中,多线程就像是一场精心编排的交响乐。每个线程都是乐团中的一个乐手,他们各自演奏着自己的部分,却又和谐地共同完成整场演出。本文将带你走进Java多线程的世界,让你从零基础到能够编写基本的多线程程序。
32 1
|
27天前
|
Java 数据处理 开发者
Java多线程编程的艺术:从入门到精通####
【10月更文挑战第21天】 本文将深入探讨Java多线程编程的核心概念,通过生动实例和实用技巧,引导读者从基础认知迈向高效并发编程的殿堂。我们将一起揭开线程管理的神秘面纱,掌握同步机制的精髓,并学习如何在实际项目中灵活运用这些知识,以提升应用性能与响应速度。 ####
44 3
|
29天前
|
Java
Java中的多线程编程:从入门到精通
本文将带你深入了解Java中的多线程编程。我们将从基础概念开始,逐步深入探讨线程的创建、启动、同步和通信等关键知识点。通过阅读本文,你将能够掌握Java多线程编程的基本技能,为进一步学习和应用打下坚实的基础。
|
1月前
|
开发框架 IDE Java
java制作游戏,如何使用libgdx,入门级别教学
本文是一篇入门级教程,介绍了如何使用libgdx游戏开发框架创建一个简单的游戏项目,包括访问libgdx官网、设置项目、下载项目生成工具,并在IDE中运行生成的项目。
51 1
java制作游戏,如何使用libgdx,入门级别教学
|
1月前
|
存储 安全 Java
从入门到精通:Java Map全攻略,一篇文章就够了!
【10月更文挑战第19天】本文介绍了Java编程中重要的数据结构——Map,通过问答形式讲解了Map的基本概念、创建、访问与修改、遍历方法、常用实现类(如HashMap、TreeMap、LinkedHashMap)及其特点,以及Map在多线程环境下的使用和性能优化技巧,适合初学者和进阶者学习。
45 4
|
30天前
|
Java
[Java]Socket套接字(网络编程入门)
本文介绍了基于Java Socket实现的一对一和多对多聊天模式。一对一模式通过Server和Client类实现简单的消息收发;多对多模式则通过Server类维护客户端集合,并使用多线程实现实时消息广播。文章旨在帮助读者理解Socket的基本原理和应用。
23 1
下一篇
无影云桌面