Java刷题训练第一期

Java刷题训练第一期

个人主页:手握风云

专栏:Java刷题训练营


1. 字符转ASCII码

问题描述:BoBo教KiKi字符常量或字符变量表示的字符在内存中以ASCII码形式存储。BoBo出了一个问题给KiKi,输入一个字符,输出该字符相应的ASCII码。

输入描述:一行,一个字符。

输出描述:一行,输出输入字符对应的ASCII码。

算法分析:在Java当中,没有针对字符的输入,只能使用针对字符串的输入,然后再使用charAt方法取第一个元素。然后通过强转将字符转化成整型。

代码如下:

```java
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner sca = new Scanner(System.in);
        char c = sca.nextLine().charAt(0);//取第一个元素
        int num = (int)c;
        System.out.println(num);
    }
}
```

2. 实现四舍五入

问题描述:将浮点数转换为整数类型,要求四舍五入。

输入描述:随机输入的浮点数

输出描述:四舍五入之后的整数

算法分析:这里要求输入一个浮点数,并且没规定正负,就需要考虑小数部分是正的还是负的。先输入一个浮点数,再强转成整型,相减得到小数部分去进行判断。

代码如下:

```java
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner num = new Scanner(System.in);
        double d = num.nextDouble();
        int a = (int) d;//强转

        if(a >= 0) {
            if (d - a * 1.0 < 0.5) {
                //取小数部分,如果小于0.5,舍;
                System.out.println(a);
            } else {
                //如果大于0.5,入;
                System.out.println(a + 1);
            }
        } else{
            if (d - a * 1.0 < -0.5) {
                //取小数部分,如果小于-0.5,入;
                System.out.println(a-1);
            } else {
                //如果大于-0.5,舍;
                System.out.println(a);
            }
        }
    }
}
```

3. 字符菱形

问题描述:读入一个字符,然后在屏幕上显示一个用这个字符填充的对角线长5个字符,倾斜放置的菱形。

输入描述:输入一个char类型字符

输出描述:输出一个用这个字符填充的对角线长5个字符,倾斜放置的菱形

输出样例:

Java刷题训练第一期

算法分析:首先还是要将取字符串的第一个元素转成字符。因为形状已经给定了,所以直接输出就可以。但要注意一下第三行的输出,如果我们写成下面的代码,就会输出175。因为c是char类型,是ASCII字符, 能被解析, 字符串+号才算被当成加法运算。

```java
System.out.println(c+c+c+c+c);
```

代码如下:

```java
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner sca = new Scanner(System.in);
        char c = sca.nextLine().charAt(0);
        System.out.println(" "+" "+c+" "+" ");
        System.out.println(" "+c+c+c+" ");
        System.out.println(c+""+c+c+c+""+c);
        System.out.println(" "+c+c+c+" ");
        System.out.println(" "+" "+c+" "+" ");
    }
}
```

4. 大小写转化

问题描述:实现字母的大小写转换。多组输入输出。

输入描述:多组输入,每一行输入大写字母。

输出描述:针对每组输入输出对应的小写字母。

算法分析:先输入一个字符串,再用toLowerCase方法转成小写字母,再取第一个元素输出。

代码如下:

```java
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner sca = new Scanner(System.in);
        while(sca.hasNextLine()){
            String str1 = sca.nextLine();
            String str2 = str1.toLowerCase();
            char ch = str2.charAt(0);
            System.out.println(ch);
        }
    }
}

```

5. 开学?

问题描述:小S知道原计划星期X开学,通知开学时间延期N天,请问开学日期是星期几(星期日用7表示)?

输入描述:输入包含两个数字X,N(1≤X≤7, 1≤N≤1000)。

输出描述:输出一个数字,表示开学日期是星期几。

算法分析:让X+N对7进行取模运算。如果余数是1——6,直接输出;如果余数是0,则输出7。

代码如下:

```java
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner num = new Scanner(System.in);
        int X = num.nextInt();
        int N = num.nextInt();
        int a = (X + N) % 7;
        if (a == 0) {
            System.out.println(7);
        } else {
            System.out.println(a);
        }
    }
}
```

6. 获得月份天数

描述:KiKi想获得某年某月有多少天,请帮他编程实现。输入年份和月份,计算这一年这个月有多少天。

输入描述:多组输入,一行有两个整数,分别表示年份和月份,用空格分隔。

输出描述:针对每组输入,输出为一行,一个整数,表示这一年这个月有多少天。

算法分析:我们先从月份上进行判断。我们先不管2月,1——7月,奇数月是31天,偶数月是30天;8——12月,奇数月是30天,偶数月是31天。接着判断输入的年份是否是闰年。

代码如下:

```java
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner num = new Scanner(System.in);
        while (num.hasNextInt()) {
            int year = num.nextInt();
            int month = num.nextInt();
            if (month <= 7 && month != 2) {
                if (month % 2 == 1) {
                    System.out.println(31);
                } else if (month % 2 == 0) {
                    System.out.println(30);
                }
            } else if (month == 2) {
                if ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0) {
                    System.out.println(29);
                } else {
                    System.out.println(28);
                }
            } else {
                if (month % 2 == 0) {
                    System.out.println(31);
                } else {
                    System.out.println(30);
                }
            }
        }
    }
}
```

7. 小乐乐找最大数

问题描述:小乐乐获得4个最大数,请帮他编程找到最大的数。

输入描述:一行,4个整数,用空格分开。

输出描述:一行,一个整数,为输入的4个整数中最大的整数。

算法分析:首先用循环遍历数组,对4个元素进行输入;然后定义一个max变量,假设数组的第一个元素是最大值,遍历数组所有元素与max进行比较,找出最大值。

代码如下:

```java
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        int size = 4;//数组长度为4;
        Scanner num = new Scanner(System.in);
        int[] arrays = new int[size];
        for (int i = 0; i < size; i++) {
            arrays[i] = num.nextInt();//经过4次循环,输入4个数
        }
        int max = arrays[0];//先假设第一个元素是最大值
        for (int i = 0; i < arrays.length; i++) {
            if (arrays[i] > max) {
                max = arrays[i];
            }
        }
        System.out.println(max);
    }
}
```

8. 统计数据正负个数

问题描述:输入10个整数,分别统计输出正数、负数的个数。

输入描述:输入10个整数(范围-231~231-1),用空格分隔。

输出描述:两行,第一行正数个数,第二行负数个数。

算法分析:同上一题类似,也是需要遍历数组元素,找出所有的正数与负数,并自加统计个数。

代码如下:

```java
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        int size = 10;
        Scanner num = new Scanner(System.in);
        int[] arrays = new int[size];
        for (int i = 0; i < size; i++) {
            arrays[i] = num.nextInt();
        }
        int count1 = 0;
        int count2 = 0;
        for (int i = 0; i < arrays.length; i++) {
            if (arrays[i] > 0) {
                count1++;
            } else if (arrays[i] < 0) {
                count2++;
            }
        }
        System.out.println("positive:" + count1);
        System.out.println("negative:" + count2);
    }
}

```

9. 邮箱验证

问题描述:请根据给出的正则表达式来验证邮箱格式是否合法,如果用户输入的格式合法则输出「邮箱格式合法」,否则输出「邮箱格式不合法」。

输入描述:任意字符串

输出描述:根据输入的邮箱格式判断其合法于不合法,若输入字符串符合邮箱格式则输出邮箱格式合法,否则输出邮箱格式不合法

算法分析:本题需要有两个注意的点,一个是matches方法需要进行匹配,另一个就是正则表达式的写法,也是本题的难点。"[a-zA-Z0-9]+@[a-zA-Z0-9]+\.[a-zA-Z0-9]+",这个正则表达式,修饰符+表示至少匹配其中的一个字符

Java刷题训练第一期代码如下:

```java
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        String str1 = in.nextLine();
        String emailMatch = "[a-zA-Z0-9]+@[a-zA-Z0-9]+\.[a-zA-Z0-9]+";
        if (str1.matches(emailMatch)) {
            System.out.println("邮箱格式合法");
        } else {
            System.out.println("邮箱格式不合法");
        }
    }
}
```

10. 求最小公倍数

问题描述:编写一个方法,该方法的返回值是两个不大于100的正整数的最小公倍数

输入描述:两个int类型变量作为方法的参数

输出描述:int类型的变量,值为两个数的最小公倍数

```java
import java.util.*;

public class Main {
    public static void main(String[] args) {
        Scanner console = new Scanner(System.in);
        int m = console.nextInt();
        int n = console.nextInt();
        int result = getCM(m, n);
        System.out.println(result);
    }

    public static int getCM(int m, int n){

        //write your code here......


    }
}
```

算法分析:方法的返回值是int,方法名称、参数都给了我们,所以就写成如下格式。求最小公倍数,一定小于等于两个数的乘积。利用for循环,找出能同时对两个数同时取模运算余数为0的数,然后返回。

```java
public static int getCM(int m, int n)
```

代码如下:

```java
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner console = new Scanner(System.in);
        int m = console.nextInt();
        int n = console.nextInt();
        int result = getCM(m, n);
        System.out.println(result);
    }

    public static int getCM(int m, int n) {
        for (int i = 2; i < m * n ; i++) {
            if (i % m == 0 && i % n == 0) {
                return i;
            }
        }
        return m * n;
    }
}
```

如果上述问题,各位大佬有更高效的做法,欢迎评论区留言。

文章整理自互联网,只做测试使用。发布者:Lomu,转转请注明出处:https://www.it1024doc.com/4982.html

(0)
LomuLomu
上一篇 2024 年 12 月 31 日 上午12:42
下一篇 2024 年 12 月 31 日

相关推荐

  • 【2024最新版可用】Intellij IDEA破解教程,附IDEA激活码

    IntelliJ IDEA 是一种广受欢迎的 Java 集成开发环境,被认为是最佳的 Java 开发工具之一。本文将分享如何通过脚本免费激活 IDEA 及 Jetbrains 全家桶工具,支持 2021 及以上版本,包括最新版本。 一、下载并安装 IDEA 首先,前往 JetBrains 官网下载最新版本的 IDEA。安装过程非常简单,按照提示一步步操作即可…

    未分类 2024 年 7 月 15 日
    2.5K00
  • 【算法解析】分治策略下的归并排序实现

    算法深度剖析:分治法的经典应用一、递归实现原理探究1.核心思想2.实现步骤2.1边界条件处理2.2基础排序验证2.3结果回溯机制3.本质特征4.代码实现二、递归调用机制解析1.执行流程分析2.函数栈帧研究2.1递归栈帧动态2.2合并操作栈帧三、性能指标评估1.空间需求分析2.时间效率计算 一、递归实现原理探究 1.核心思想 分治策略的数学表达可以转化为子问题…

    2025 年 5 月 15 日
    34200
  • Java Druid 面试题

    Druid连接池在项目中有哪些优势? 性能优越:Druid采用了高效的连接管理机制,可以快速地创建和回收数据库连接,减少了连接的创建和销毁带来的性能开销。 监控与统计:Druid提供了详细的监控信息,包括连接池的状态、SQL执行的统计信息等,这有助于性能调优和问题诊断。 SQL日志记录:Druid内置了SQL执行日志记录功能,可以记录所有SQL语句的执行情况…

    未分类 2025 年 1 月 10 日
    52300
  • 掌握Java对象本质:从打工者到技术专家的飞跃

    1.1 从机器视角到问题视角的演变 在计算机科学的发展历程中,我们见证了从机器视角到问题视角的深刻转变。这一转变不仅体现了编程语言和技术的进步,更反映了我们对问题解决方式理解的深化。 起初,计算机编程主要依赖于机器视角。汇编语言作为最初的编程语言,要求我们按照计算机的硬件结构来编写代码。以下是一个简单的汇编语言例子,用于在x86 架构的计算机上将两个数相加:…

    2024 年 12 月 28 日
    52300
  • 【C++】右值引用全面揭秘:解锁 C++11 的性能革命与移动语义奥秘!

    文章目录 右值和左值的基本概念 左值引用和右值引用 右值引用的主要用途 移动语义 只有拷贝构造和赋值重载而没有移动语义的传值返回 增加移动构造和移动赋值的传值返回 引用折叠与完美转发 C++11 引入了右值引用,这是 C++ 语言的一个重要特性,其目的是为了提高程序的性能,尤其是在对象的传递和资源管理方面。与左值引用相比,右值引用解决了在传返回值时的不足,显…

    未分类 2024 年 12 月 28 日
    57400

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信