java编程强化练习(一)

news2025/1/13 13:30:41

1. 素数因子数字和

【问题描述】从键盘终端输入一个正的整数,求其所有素数因子各位上数字之和。例如:44=2*2*11,素数因子为2,2,11,和为2+2+1+1=4
【输入形式】一个正的整数
【输出形式】整数的所有素数因子各位上数字之和
【样例输入】100
【样例输出】14
【样例说明】
【评分标准】

import java.math.BigInteger;
import java.util.Scanner;

public class Main {

    public static boolean prime(int num)
    {
        for(int i=2;i<Math.sqrt(num);i++)
        {
            if(num%i==0)
                return false;
        }
        return true;
    }
    public static void main(String[] args) {
        Scanner scanner=new Scanner(System.in);
        int num=scanner.nextInt();
        int sum=0;
        for (int i = 2; i <= num; i++) {
            while((num % i) == 0 &&prime(i))
            {
                    for(int j=i;j>0;j=j/10)
                    {
                        sum=sum+j%10;
                    }

                num=num/i;
            }
        }
        System.out.println(sum);
    }
}

2. 计算公式:求π的值b

【问题描述】

给定一个精度值e,用下列公式计算&pi;的近似值,要求前后两次&pi;的迭代之差的绝对值小于e,给出相应的最小迭代次数n和最后一次计算的&pi;的值。
&pi;/2=1+1!/3+2!/(3&times;5)+3!/(3&times;5&times;7)+&hellip;+(n-1)!/(3&times;5&times;7&times;&hellip;&times;(2n-1))

【输入形式】

从控制台输入e( e>=0.000001 )的值。

【输出形式】

输出迭代次数n和最后一次计算的&pi;的值(以一个空格分隔,并且输出&pi;时要求小数点后保留7位有效数字)。

【样例输入】

0.000003

【样例输出】

19 3.1415912

【样例说明】

输入的精度e为0.000003,当n为17时,计算的&pi;值为3.1415864,n为18时计算的&pi;值为3.1415896,两者之差为0.0000032,大于给定的精度值,所以需要继续计算。当n为19时,计算的&pi;值为3.1415912,与上次之差为0.0000016,小于给定的精度值,所以最小迭代次数为19,输出的&pi;值为3.1415912。

注意:
(1) 为保证计算精度,请使用double数据类型保存计算数据。
(2) 应至少迭代两次,即:n>=2。

【评分标准】

该题要求输出最小迭代次数和&pi;的值,共有5个测试点。

import java.math.BigDecimal;
import java.text.DecimalFormat;
import java.util.Scanner;
class Main{
    public static void main(String arg[]) {
        Scanner scanner = new Scanner(System.in);
        double e = scanner.nextDouble();
        int a = 2;
        double sum = 1.0;
        double t = 1.0;
        while (2*t>=e) {
            double pro = 1.0;
            double b = 1.0;
            for (int i = 1; i <=a-1; i
                    ++) {
                pro = pro * i;
                b = b * (2 * i + 1);
            }
            t = pro / b;
            sum = sum + t;
            a++;
        }
        DecimalFormat s=new DecimalFormat("#0.0000000");
        System.out.print((a-1) + " ");
        System.out.println(s.format(sum*2.0) );
    }
        }

3. 字母频率统计

【问题描述】

编写程序从标准输入中读入一段英文,统计其中小写字母出现次数,并以柱状图的形式显示其出现次数。

【输入形式】

在标准输入上输入一段英文文章(可能有一行,也可能有多行),在新的一行的开头输入ctrl+z键表示结束。

【输出形式】

在屏幕上依次输出表示每个小写字母出现次数的柱状图(以&ldquo;*&rdquo;字符表示柱状图,空白处用空格字符表示,某个小写字母出现多少次,就显示多少&ldquo;*&rdquo;字符;柱状图的高度以出现最多的字母次数为准),在最后一行依次输出26个小写字母。

【样例输入】

The computing world has undergone a
revolution since the publication of
The C Programming Language in 1978.


【样例输出】

【样例说明】

在输入的英文短文中,小写字母a出现了6次,所以其上输出了6个字符"*"。出现次数最多的是字母n,所以柱状图的高度为9个字符。字母j没有出现,所以其上都为空格字符。

【评分标准】

该题要求输出柱状图表示的字母出现次数,共有5个测试点。

import java.util.Scanner;

public class LetterHistogram {
    public static void main(String[] args) {
        // 读取输入文本
        Scanner scanner = new Scanner(System.in); // 创建Scanner对象以读取用户输入
        StringBuilder builder = new StringBuilder(); // 用于构建用户输入的文本
        while (scanner.hasNextLine()) { // 检查是否还有下一行输入,这个方法也可以记一下。如果存在下一行,则返回true;如果输入源已经没有更多的行可供读取,则返回false。
            String line = scanner.nextLine(); // 读取用户输入的当前行,就是输入哪
            if (line.isEmpty()) { // 如果当前行为空行,则退出循环
                break;
            }
            builder.append(line).append("\n"); // 将当前行添加到StringBuilder对象中,就相当于是将三个不同的对象合为一个对象,便于遍历和输出(append就是附加增补的意思,可以记住这个方法)。
        }
        String text = builder.toString(); // 将StringBuilder对象转换为字符串,得到用户输入的完整文本

        // 统计小写字母出现次数
        int[] letterCounts = new int[26]; // 创建长度为26的整型数组,用于存储每个字母出现的次数
        for (char c : text.toCharArray()) { // 遍历文本中的每个字符,text.toCharArray()将字符串转换为一个字符数组,以便可以遍历每个字符并进行相应的操作。
            if (Character.isLowerCase(c)) { // 如果字符是小写字母
                letterCounts[c - 'a']++; // 增加对应字母的计数
            }
        }

        // 计算最多出现次数
        int maxCount = 0; // 用于存储出现次数的最大值
        for (int count : letterCounts) { // 遍历字母计数数组
            if (count > maxCount) { // 如果当前计数大于最大值
                maxCount = count; // 更新最大值
            }
        }

        // 输出柱状图
        for (int i = maxCount; i > 0; i--) { // 从最大值开始递减
            StringBuilder row = new StringBuilder(); // 用于构建柱状图的每一行
            for (int count : letterCounts) { // 遍历字母计数数组
                if (count >= i) { // 如果计数大于等于当前行数
                    row.append("*"); // 添加"*"表示该位置有一个小写字母
                } else {
                    row.append(" "); // 添加空格表示该位置没有小写字母
                }
            }
            System.out.println(row); // 输出当前行的柱状图
        }

        // 输出字母
        for (char c = 'a'; c <= 'z'; c++) { // 遍历小写字母
            System.out.print(c); // 输出字母
        }
    }
}

scanner.nextLine(); // 读取换行符,在这里解释一下为什么,这一句能不能去掉         //如果不使用scanner.nextLine()读取换行符,会导致在读取方阵元素之前,下一行的第一个元素会被跳过。         //在Java中,当你使用nextInt()方法读取一个整数后,光标会停留在该整数后的换行符上。         // 如果直接进入下一个循环,使用nextLine()读取下一行时,会返回一个空字符串,因为它会读取到之前的换行符,而不是下一行的内容。         //为了解决这个问题,我们需要在调用nextLine()之前,使用一个额外的scanner.nextLine()来读取并忽略掉前一个整数后的换行符。这样,下一行的内容才会被正确读取。         //所以一定要记住这种多行输入的字符串要先读取换行符,否则整个程序的运行会出现无法找到的错误。

4.求三角形面积

【问题描述】

若已知三角形三个边的长度分别为a,b,c(并假设三个边长度的单位一致,在本编程题中忽略其单位),则可以利用公式:

    

求得三角形的面积,其中:s=(a+b+c)/2。编程实现从控制台读入以整数表示的三个边的长度(假设输入的长度肯定可以形成三角形),然后利用上述公式计算面积并输出,结果小数点后保留3位有效数字。

【输入形式】

从控制台输入三个整数表示三角形三个边的长度,以空格分隔三个整数。

【输出形式】

向控制台输出求得的三角形的面积,小数点后保留三位有效数字。

【输入样例】

4 4 6

【输出样例】

7.937

【样例说明】

输入的三角形三个边的长度分别为4、4、6,利用上述计算公式可以求得三角形的面积为7.937,小数点后保留三位有效数字。

【评分标准】

该题要求输出三角形的面积,共有5个测试点。

import java.util.Scanner;

public class TriangleArea {
    public static void main(String[] args) {
        // 读取三个整数表示三角形的边长
        Scanner scanner = new Scanner(System.in);//输入
        int a = scanner.nextInt();//输入a
        int b = scanner.nextInt();//输入b
        int c = scanner.nextInt();//输入c

        // 计算半周长
        double s = (a + b + c) / 2.0;//这里要注意要取浮点型,否则最后结果会出错。

        // 计算三角形的面积
        double area = Math.sqrt(s * (s - a) * (s - b) * (s - c));

        // 输出结果,保留三位有效数字
        System.out.printf("%.3f", area);//这种保留小数的方法是比较简单的,还有其他方法,但这个最好用,在第二题中就有一种。
    }
}

5.求小岛面积

【问题描述】

用一个二维方阵(最小为3X3,最大为9X9)表示一片海域。方阵中的元素只由0和1组成。1表示海岸线。计算由海岸线围起来的小岛面积(即:由1围起来的区域中0的个数)。如下图所示6X6方阵表示的小岛面积为9:
0 0 0 1 0 0
0 0 1 0 1 0
0 1 0 0 0 1
1 0 0 0 1 0
1 0 1 0 1 0
1 1 0 1 1 1
上述方阵表示的海域满足下面两个要求:
1、小岛只有一个。
2、用1表示的海岸线肯定可以封闭成一个小岛,但有可能是凸的,也有可能是凹的。所以在判断时:对于方阵中的任意一个元素0,如果其位于同一行上的两个1之间,并且位于同一列上的两个1之间,则该元素肯定在1围起来的区域中。不符合该规定的其它情况不考虑。

【输入形式】

先从标准输入中输入方阵的阶数,然后从下一行开始输入方阵的元素(只会输入0或1),各元素之间以一个空格分隔,每行最后一个元素后没有空格,但会有回车换行符。

【输出形式】

在标准输出上输出用整数表示的小岛面积。

【输入样例】

6
0 0 0 1 0 0
0 0 1 0 1 0
0 1 0 0 0 1
1 0 0 0 1 0
1 0 1 0 1 0
1 1 0 1 1 1

【输出样例】

9

【样例说明】

输入是6X6的方阵。该方阵中由1围起来的区域内有9个0,所以输出的小岛面积为9。注意:最下方的三个元素1(即第5行第3列的1、第6行第2列的1、第6行第4列的1)组成了一个凹形的海岸线,第6行第3列的0不在海岸线内,所以不应算作小岛面积。

【评分标准】

该题要求输出用整数表示的小岛面积,共有5个测试点。

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int[][] a;
        int i, j, n, d = 0, p = 0, x, y;
        n = scanner.nextInt(); // 方阵阶数
        a = new int[n][n];
        // 根据阶数创建方阵
        for (i = 0; i <= n - 1; i++) {
            for (j = 0; j <= n - 1; j++) {
                a[i][j] = scanner.nextInt();
            }
        }
        // 遍历方阵
        for (i = 0; i <= n - 1; i++) {
            for (j = 0; j <= n - 1; j++) {
                if (a[i][j] == 1) // 遇到“1”则跳过
                    continue;
                p = 0; // 用来记被遍历到的数字的上下左右遇到的1的个数
                // 判断左边有无1,有则p+1
                for (x = i; x >= 0; x--) {
                    y = j;
                    if (a[x][y] == 1) {
                        p++;
                        break;
                    }
                }
                // 判断右边有无1,有则p+1
                for (x = i; x <= n - 1; x++) {
                    y = j;
                    if (a[x][y] == 1) {
                        p++;
                        break;
                    }
                }
                // 判断下边有无1,有则p+1
                for (y = j; y >= 0; y--) {
                    x = i;
                    if (a[x][y] == 1) {
                        p++;
                        break;
                    }
                }
                // 判断上边有无1,有则p+1
                for (y = j; y <= n - 1; y++) {
                    x = i;
                    if (a[x][y] == 1) {
                        p++;
                        break;
                    }
                }
                if (p == 4) // 上下左右都有1说明该点在岛上,则d+1
                    d++;
            }
        }
        System.out.println(d);
    }
}

6.查找关键字出现的位置(标准输入)

【问题描述】

从标准输入中读入一行C源程序,查找该行程序中控制流关键字(while, for, if)的出现位置。按出现顺序输出其出现的位置(用在该行上第几个字符表示)。要求字符串常量中出现的关键字不应计算,同时该行C程序满足下列规定:
1、该行程序符合C语言语法要求,在该行程序上有可能有多条C语言语句,字符数不会超过300。
2、双引号只会用在字符串常量中,其它地方不会出现双引号字符。
3、程序中的所有标识符只由字母和数字组成。
4、程序中没有注释语句。

【输入形式】

从标准输入中读入一行C语言源程序,在行的末尾有回车换行。

【输出形式】

按照出现顺序在标准输出上输出关键字出现的位置,每行输出一个关键字的位置。位置的输出格式是:先输出关键字,后面紧跟着冒号:,然后是用整数表示的在该行上的位置。若没有关键字则什么都不输出。

【输入样例1】

假如从标准输入读入的一行程序为:
scanf ( "%d" , &ifn ); for ( i=0 ; i<ifn ; i++ ) scanf ( "%d" , &a[i] );

【输出样例1】

for:24

【样例说明1】

在输入的一行C语言程序中只有一个控制流关键字for。for关键字在该行上的第24个字符位置处,所以输出:for:24。

【输入样例2】

假如从标准输入读入的一行程序为:
while (i<n) {  if(if1<forAndwhile[i])    if1=forAndwhile[i]; }  for(i=0;i<n;i++)sum+=forAndwhile[i]; for(i=0;i<n;i++)mul*=forAndwhile[i]; printf("The max of for and while is :%d\n",if1);

【输出样例2】

while:1
if:16
for:65
for:102

【样例说明2】

在该程序中有一个while、一个if和两个for关键字。其中while位于第1个字符处,if在第16个字符处,第一个for在第65个字符处,第二个for在第102个字符处,分别按顺序输出。注意:字符串常量中出现的for和while不是关键字,所以不应输出。同样,在一些变量名中作为子串出现的if、for和while也不是关键字。

【评分标准】

import java.util.Scanner;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        String line = scanner.nextLine();

        // 使用正则表达式匹配控制流关键字
        Pattern pattern = Pattern.compile("\\b(while|for|if)\\b");
        Matcher matcher = pattern.matcher(line);

        int index = 0;
        while (matcher.find()) {
            String keyword = matcher.group();

            // 检查关键字是否在字符串常量中
            if (!isInsideStringConstant(line, matcher.start())) {
                index++;
                System.out.println(keyword + ":" + (matcher.start()+1));
            }
        }
    }

    // 检查指定位置是否在字符串常量中
    private static boolean isInsideStringConstant(String line, int position) {
        boolean insideString = false;
        boolean insideEscapeSequence = false;

        for (int i = 0; i <position; i++) {
            char currentChar = line.charAt(i);

            if (!insideEscapeSequence) {
                if (currentChar == '\"') {
                    insideString = !insideString;
                } else if (currentChar == '\\') {
                    insideEscapeSequence = true;
                }
            } else {
                insideEscapeSequence = false;
            }
        }

        return insideString;
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1263899.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

用通俗的方式讲解Transformer:从Word2Vec、Seq2Seq逐步理解到GPT、BERT

直到今天早上&#xff0c;刷到CSDN一篇讲BERT的文章&#xff0c;号称一文读懂&#xff0c;我读下来之后&#xff0c;假定我是初学者&#xff0c;读不懂。 关于BERT的笔记&#xff0c;其实一两年前就想写了&#xff0c;迟迟没动笔的原因是国内外已经有很多不错的资料&#xff0…

C语言基础程序设计题

1.个人所得税计算 应纳税款的计算公式如下&#xff1a;收入<&#xff1d;1000元部分税率为0&#xff05;&#xff0c;2000元>&#xff1d;收入>1000元的部分税率为5&#xff05;&#xff0c;3000元>&#xff1d;收入>2000元的部分税率为10&#xff05;&#xf…

【C语言加油站】函数栈帧的创建与销毁 #保姆级讲解

函数栈帧的创建与销毁 导言一、计算机硬件1.冯•诺依曼机基本思想2.冯•诺依曼机的特点&#xff1a;3.存储器3.1 分类3.2 内存的工作方式3.3 内存的组成 4.寄存器4.1 基本含义4.2 寄存器的功能4.3 工作原理4.4 分类4.4.1 通用寄存器组AX(AH、AL)&#xff1a;累加器BX(BH、BL)&a…

Opencv-C++笔记 (19) : 分水岭图像分割

文章目录 一、基于距离变换与分水岭的图像分割1、图像分割2、距离和变换与分水岭距离变换常见算法有两种分水岭变换常见的算法 3、距离变换API函数接口4、watershed 分水岭函数API接口步骤 5、代码 一、基于距离变换与分水岭的图像分割 1、图像分割 图像分割(Image Segmentat…

大坝安全监测的内容及作用

大坝安全监测是指对大坝水雨情沉降、倾斜、渗压以及大坝形状特征有效地进行监测&#xff0c;及时发现潜在的安全隐患和异常情况&#xff0c;以便大坝管理人员能够做出科学决策&#xff0c;以确保大坝安全稳定运行。 大坝安全监测的主要内容 1.表面位移监测&#xff1a;监测大坝…

Python基础:推导式(Comprehensions)详解

1. 推导式概念 Python推导式&#xff08;comprehensions&#xff09;是一种简洁而强大的语法&#xff0c;用于从已存在的数据&#xff08;列表、元组、集合、字典等&#xff09;中创建新的数据结构。推导式包括&#xff1a; 列表推导式元组推导式字典推导式集合推导式 2. 列表…

鸿蒙原生应用/元服务开发-AGC分发如何生成密钥和和证书请求文件

HarmonyOS通过数字证书&#xff08;.cer文件&#xff09;和Profile文件&#xff08;.p7b文件&#xff09;等签名信息来保证应用的完整性&#xff0c;应用如需上架到华为应用市场必须通过签名校验。因此&#xff0c;开发者需要使用发布证书和Profile文件对应用进行签名后才能发布…

Gee教程3.实现前缀树路由

需要完成的目标 使用 Trie 树实现动态路由(dynamic route)解析。支持两种模式:name和*filepath&#xff0c;(开头带有:或者*) 这里前缀树的实现修复了Go语言动手写Web框架 - Gee第三天 前缀树路由Router | 极客兔兔​​​​​​ 中路由冲突的bug。 Trie树简介 之前&#xff0…

20世纪的葡萄酒有哪些创新?

葡萄酒是用酵母发酵的&#xff0c;直到20世纪中叶&#xff0c;这一过程都依赖于自然产生的酵母。这些发酵的结果往往不一致&#xff0c;而且由于发酵时间长&#xff0c;容易腐败。 酿酒业最重要的进步之一是在20世纪50、60年代引进了地中海的纯发酵菌种酿酒酵母&#xff0c;俗称…

全面介绍SSO(单点登录)

全面介绍SSO&#xff08;单点登录&#xff09; SSO英文全称Single SignOn&#xff0c;单点登录。SSO是在多个应用系统中&#xff0c;用户只需要登录一次就可以访问所有相互信任的应用系统。它包括可以将这次主要的登录映射到其他应用中用于同一个用户的登录的机制。它是目前比…

C++类与对象(7)—友元、内部类、匿名对象、拷贝对象时编译器优化

目录 一、友元 1、定义 2、友元函数 3、友元类 二、内部类 1、定义 2、特性&#xff1a; 三、匿名对象 四、拷贝对象时的一些编译器优化 1、传值&传引用返回优化对比 2、匿名对象作为函数返回对象 3、接收返回值方式对比 总结&#xff1a; 一、友元 1、定义…

0005Java程序设计-ssm基于微信小程序的校园求职系统

文章目录 摘 要目 录系统设计开发环境 编程技术交流、源码分享、模板分享、网课分享 企鹅&#x1f427;裙&#xff1a;776871563 摘 要 随着我国经济迅速发展&#xff0c;人们对手机的需求越来越大&#xff0c;各种手机软件也都在被广泛应用&#xff0c;但是对于手机进行数据…

因为计算机中丢失MSVCP140.dll,无法启动此程序运行软件的解决方法

msvcp140.dll重新安装五个解决方法与msvcp140.dll文件的作用和丢失对电脑的影响介绍 正文&#xff1a; 在计算机使用过程中&#xff0c;我们经常会遇到一些错误提示&#xff0c;其中最常见的就是“缺少xxx.dll文件”。而msvcp140.dll就是其中之一。那么&#xff0c;msvcp140.…

哈希表——闭散列表

该哈希表实现是闭散列实现法。 闭散列表&#xff1a; 闭散列&#xff1a;也叫开放定址法&#xff0c;当发生哈希冲突时&#xff0c;如果哈希表未被装满&#xff0c;说明在哈希表中必然还有空位置&#xff0c;那么可以把key存放到冲突位置中的“下一个” 空位置中去。 那如何寻…

sprintboot快速初始化【Springboot】

1.首先选择创建项目 2.填写对应的项目信息 一定要勾选maven&#xff0c;否则没有pom文件&#xff0c;选择next 3.选择应用场景 点击 create&#xff0c;DIEA就会根据你的选择自动创建项目骨架&#xff1b; 4.创建一个控制层 随便创建一个控制层&#xff0c;测试一下项目是否…

阿里云语雀频繁崩溃,有什么文档管理工具是比较稳定的?

10月23 日14:00左右&#xff0c;蚂蚁集团旗下的在线文档编辑与协同工具语雀发生服务器故障&#xff0c;在线文档和官网都无法打开。直到当天晚上22:24&#xff0c;语雀服务才全部恢复正常。从故障发生到完全恢复正常&#xff0c;语雀整个宕机时间将近 8 小时&#xff0c;如此长…

麒麟V10桌面搭建FTP服务

1.1介绍 FTP&#xff1a;File transfer protocol &#xff08;文件传输协议&#xff09;是 TCP/IP 协议组中的协议之一。FTP协议包括两个组成部分&#xff0c;其一为FTP服务器&#xff0c;其二为FTP客户端。其中FTP服务器用来存储文件&#xff0c;用户可以使用FTP客户端通过FT…

Java变量理解

成员变量VS局部变量的区别 语法形式&#xff1a;从语法形式上看&#xff0c;成员变量是属于类的&#xff0c;而局部变量是在代码块或方法中定义的变量或是方法的参数&#xff1b;成员变量可以被 public,private,static 等修饰符所修饰&#xff0c;而局部变量不能被访问控制修饰…

深度盘点:100 个 Python 数据分析函数总结

经过一段时间的整理&#xff0c;本期将分享我认为比较常用的100个实用函数&#xff0c;这些函数大致可以分为六类&#xff0c;分别是统计汇总函数、数据清洗函数、数据筛选、绘图与元素级运算函数、时间序列函数和其他函数。 技术交流 技术要学会交流、分享&#xff0c;不建议…