【Java入门】有关的经典题型练习详细讲解

这篇具有很好参考价值的文章主要介绍了【Java入门】有关的经典题型练习详细讲解。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

【Java入门】有关的经典题型练习详细讲解
前言

📕作者简介:热爱跑步的恒川,致力于C/C++、Java、Python等多编程语言,热爱跑步,喜爱音乐的一位博主。
📗本文收录于Java入门篇系列,该专栏主要讲解:什么是java、java的数据类型与变量、运算符、程序的逻辑控制、方法的使用、数组的定义与使、类和对象、继承和多态、抽象类和接口、认识String类、认识异常等……持续更新,请大家拭目以待恒川的专栏!
📘相关专栏C语言初阶、C语言进阶、恒川的日常汇报系列等,大家有兴趣的可以看一看
📙Python零基础入门系列,正在发展中,喜欢Python的朋友们可以关注一下哦!


判定一个数字是否是素数

判定一个数字是否是素数

public static void main(String[] args) {
            int n = 9;
            int i = 2;
            for (; i <= Math.sqrt(n); i++) {
                if(n % i == 0) {
                    break;
                }
            }
            //有几种情况 ? 2--》  1、 不符合循环条件 2、因为遇到了 break
            if(i > Math.sqrt(n)) {
                System.out.println(n + " 是素数! ");
            }

    }

打印 1 - 100 之间所有的素数

打印 1 - 100 之间所有的素数

public static void main(String[] args) {
        for (int n = 1; n <= 100; n++) {
            //int n = 9;
            int i = 2;
            for (; i <= Math.sqrt(n); i++) {
                if(n % i == 0) {
                    break;
                }
            }
            if (n == 1){
                System.out.println(n + "不是素数" );
                continue;
            }
            //有几种情况 ? 2--》  1、 不符合循环条件 2、因为遇到了 break
            if(i > Math.sqrt(n)) {
                System.out.println(n + " 是素数! ");
            }
        }

    }

求 1 - 100 之间出现多少次 9

求 1 - 100 之间出现多少次 9

public static void main(String[] args) {
        int count = 0;
        for (int i = 1; i <= 100; i++) {
            if(i / 10 == 9) {
                //十位是9
                count++;
            }
            if(i % 10 == 9) {
                //个位是9
                count++;
            }
        }
        count--;  //因为考虑有重复的9
        System.out.println(count);
    }

输出 1000 - 2000 之间所有的闰年

输出 1000 - 2000 之间所有的闰年

public static void main(String[] args) {
        for (int year =1000;year <= 2000; year++) {
            if(year % 100 == 0) {
                if(year % 400 == 0) {
                    System.out.println(year+" is 闰年!");
                }
            }else {
                if(year % 4 == 0) {
                    System.out.println(year+" is 闰年!");
                }
            }
        }
    }

计算1/1-1/2+1/3-1/4+1/5 …… + 1/99 - 1/100 的值,打印出结果

计算1/1-1/2+1/3-1/4+1/5 …… + 1/99 - 1/100 的值,打印出结果

public static void main2(String[] args) {
        double sum = 0;
        int flg = 1;
        for (int i = 1; i <= 100; i++) {
            sum += 1.0/i*flg;
            flg = -flg;
        }
        System.out.println(sum);
    }

获取一个数二进制序列中所有的偶数位和奇数位

获取一个数二进制序列中所有的偶数位和奇数位

图片讲解:
【Java入门】有关的经典题型练习详细讲解

public static void main(String[] args) {
        int n = 7;
        /*for (int i = 0; i < 32 ; i += 2) {
            System.out.print(((n >> i)&1)+ " ");
        }*/
        for (int i = 30; i >= 0 ; i -= 2) {
            System.out.print(((n >> i)&1)+ " ");
        }
        System.out.println();
        for (int i = 31; i >= 0 ; i -= 2) {
            System.out.print(((n >> i)&1)+ " ");
        }
    }

代码结果:

0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1

求两个数的最大公约数(最大公因数)

求两个数的最大公约数(最大公因数)

图片讲解:
【Java入门】有关的经典题型练习详细讲解

public static void main(String[] args) {
        int a = 24;
        int b = 18;
        int c = a % b;//6
        while (c != 0) {
            a = b;//18
            b = c;//6
            c = a % b;//
        }
        System.out.println(b);
    }

代码结果:

6

打印用"*"组成的X形图案

打印用"*"组成的X形图案

【Java入门】有关的经典题型练习详细讲解

public static void main3(String[] args) {
        Scanner in = new Scanner(System.in);
        // 注意 hasNext 和 hasNextLine 的区别
        while (in.hasNextInt()) { // 注意 while 处理多个 case
            int a = in.nextInt();
            for (int i = 0; i < a; i++) {
                for (int j = 0; j < a; j++) {
                    if(i == j || i+j == (a-1)){
                        System.out.print("*");
                    }else {
                        System.out.print(" ");
                    }
                }
                System.out.println();
            }
        }

求出0~999999之间的所有“水仙花数”并输出

求出0~999999之间的所有“水仙花数”并输出。(“水仙花数”是指一个三位数,其各位数字的立方和确好等于该数本身,如: 153=1^3+5^3+3^3 ,则153是一个“水仙花数”。)

public static void main(String[] args) {
        for (int i = 1; i <= 999999 ; i++) {
            //i == 123
            int count = 0;//记录位数
            int tmp = i;
            while (tmp != 0) {
                tmp /= 10;
                count++;
            }
            tmp = i;//123
            int sum = 0;
            while (tmp != 0) {
                sum += Math.pow(tmp % 10,count);
                tmp /= 10;
            }
            if(sum == i) {
                System.out.println(i);
            }
        }
    }

代码结果:

1
2
3
4
5
6
7
8
9
153
370
371
407
1634
8208
9474
54748
92727
93084
548834

模拟登录填写密码

模拟登录填写密码,输入三次机会,密码正确,则登录成功!

public static void main(String[] args) {
        Scanner in = new Scanner(System.in);

        int count = 3;
        while (count != 0) {
            System.out.println("请输入你的密码:你还有 "+ count+" 次机会!");
            String pass = in.nextLine();
            if(pass.equals("123456")) {
                System.out.println("登录成功!");
                break;
            }else {
                count--;
                System.out.println("密码错误!");
            }
        }
    }

完成猜数字游戏

完成猜数字游戏

public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        Random random = new Random();
        int randNum = random.nextInt(101);//[0,101)
        //50-100的随机数   random.nextInt(50)--[0,50)  + 50;
        while (true) {
            System.out.println("请输入你要猜的数字:");
            int num = scanner.nextInt();
            if(num < randNum) {
                System.out.println("猜小了!");
            }else if(num == randNum) {
                System.out.println("猜对了!");
                break;
            }else {
                System.out.println("猜大了!");
            }
        }
    }

写一个函数返回参数二进制中 1 的个数

写一个函数返回参数二进制中 1 的个数
比如: 7 0000 0111 3 个 1

图片讲解:
【Java入门】有关的经典题型练习详细讲解

public static void main(String[] args) {
        int n = -1;
        int count = 0;
        while (n != 0) {
            n = n & (n-1);
            count++;
        }
        System.out.println(count);
    }

代码结果:

32


如果这份博客对大家有帮助,希望各位给恒川一个免费的点赞👍作为鼓励,并评论收藏一下,谢谢大家!!!
制作不易,如果大家有什么疑问或给恒川的意见,欢迎评论区留言。文章来源地址https://www.toymoban.com/news/detail-505781.html

到了这里,关于【Java入门】有关的经典题型练习详细讲解的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 动态规划详细讲解c++|经典例题讲解认识动态规划|0-1背包问题详解

    uu们,你们好!这次的分享是动态规划,其中介绍了动态规划的相关概念和做题模板(三要素),同时为了uu们对动态规划方法有更加形象的认识,特地找了两个经典问题,和大家一起分析。并且呢,为了大家检验自己的学习成果,我专门在常用的oj上为uu们找到了相关题目的

    2024年04月11日
    浏览(60)
  • 【动态规划专栏】-- 回文串问题 -- 动态规划经典题型

    目录 动态规划 动态规划思维(基础) 状态表示(最重要) 状态转移方程(最难) 初始化(细节) 填表顺序(细节) 返回值(结果) 回文子串 ⭐⭐ 【题目解析】  【算法原理】 C++ 算法代码  最长回文子串 ⭐⭐  【题目解析】  【算法原理】 C++ 算法代码   回文串分割

    2024年02月08日
    浏览(46)
  • 【LeetCode】每日一题:链表部分经典题型

    ​👻内容专栏:《LeetCode刷题专栏》 🐨本文概括: 归纳链表部分经典题型 。 206.反转链表 、 876.链表的中间节点 、 21.合并两个有序链表 、 160.相交链表 、 141.环形链表 、 142.环形链表Ⅱ 🐼本文作者:花 碟 🐸发布时间:2023.5.17 👉 206.反转链表 题目描述:给你单链表的头

    2024年02月05日
    浏览(39)
  • 【动态规划专栏】-- 01 背包问题 -- 动态规划经典题型

    目录 背包问题概述 01 背包问题 01背包⭐⭐  【算法原理】 第一问 第二问 C++ 算法代码 复杂度分析 【空间优化 - 滚动数组】 C++ 算法代码 复杂度分析 分割等和子集⭐⭐ 【算法原理】  对于类01背包问题 C++ 算法代码  【空间优化 - 滚动数组】  C++ 算法代码 目标和⭐⭐ 【算

    2024年02月05日
    浏览(57)
  • 剑指 Offer II 024. 反转链表(经典题型)

    时间是伟大的作者,她能写出未来的结局。                               ——卓别林 目录 题目描述: 方法1:迭代法(翻指针) 方法2:头插法  方法3:递归法  给定单链表的头节点 head ,请反转链表, 并返回反转后的链表的头节点 。 示例 1: 输入:head = [1,2,3,4,5]

    2023年04月09日
    浏览(36)
  • 正则表达式和文本三剑客题型练习

    ​ 1、显示/etc/passwd文件中以bash结尾的行; 解释:使用 grep 工具来搜索文件 /etc/passwd 中匹配模式 \\\'bash$\\\' 的行。 bash$ 是一个正则表达式,其中 $ 表示行结尾。因此, \\\'bash$\\\' 匹配以 bash 结尾的行。 运行结果: ​ 2、找出\\\"netstat  -tan”命令的结果中,以‘LISTEN’后跟0或多个空白字

    2024年02月06日
    浏览(43)
  • 【数据结构】链表经典OJ题,常见几类题型(二)

    看到这类题型首先要判断链表是否相交,而相交条件: 两链尾部节点相同(地址相同, val 值相同, next 相同) 。这样我们便可 找到两链表的尾节点并判断这两个节点地址是否相同 ,若相同则两链表相交。上面这种情况两链表呈 \\\'Y\\\' 型,那么我们想一下两链表相交是否可以

    2024年02月05日
    浏览(46)
  • 【LeetCode动态规划#12】详解买卖股票I~IV,经典dp题型

    力扣题目链接(opens new window) 给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。 你只能选择 某一天 买入这只股票,并选择在 未来的某一个不同的日子 卖出该股票。设计一个算法来计算你所能获取的最大利润。 返回你可以从这笔交易中获取的最

    2023年04月24日
    浏览(54)
  • 有关C语言指针的经典例题

     1.通过地址运算符获得地址值   2.输入a,b,按从小到大的顺序输出 3 3.用指针法访问数组元素  4.从键盘输入10个整数,放入一堆数组a中,然后将该数组中的元素值依次输出  5.将10个数的最小值换到最前面的位置 6.求二维数组元素的最大值  7.用指针法实现字符串的复制 8

    2024年02月04日
    浏览(41)
  • 极限重要题型讲解(汤家凤B站笔记)

            1.先求和后极限:考的很少,太简单了 首先 推导过程是:           2.夹逼定理:重要的是知道什么时候用夹逼定理,就是当N个项中分母不齐(不齐的意思是有二次项有一次项等)或者分子不齐。             * 3.分子次数齐,分母次数齐的同时分母比分子多一次

    2023年04月20日
    浏览(44)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包