java编程题练习2

2023-05-16

【程序6】
题目:输入两个正整数m和n,求其最大公约数和最小公倍数。
/*在循环中,只要除数不等于0,用较大数除以较小的数,将小的一个数作为下一轮循环的大数,
取得的余数作为下一轮循环的较小的数,如此循环直到较小的数的值为0,返回较大的数,此数即
为最大公约数,最小公倍数为两数之积除以最大公约数。
/

import java.util.Scanner;

public class Test6 {
	public static void main(String[] args) {
		int a, b, m = 0, n = 0;
		@SuppressWarnings("resource")
		Scanner s = new Scanner(System.in);
		System.out.print( "输入两个正整数: "); 
		String mn = s.nextLine();
		String[] st = mn.split(" ");
		for (int i = 0; i < st.length; i++) {
			a = Integer.parseInt(st[0]);
			b = Integer.parseInt(st[1]);
			m = Test6.deff(a, b);
			n = a * b / m;
		}
	    System.out.println("最大公约数: " + m);
	    System.out.println("最小公倍数: " + n);
	}
	
	public static int deff(int x, int y) {
		int t;
		if(x < y) {
			t = x;
			x = y;
			y = t;
		}
		while(y != 0) {
			if(x == y) {
				return x;
			}else {
				int k = x % y;
			       	x = y;
			       	y = k;
			}
		}
		return x;
	}
}

【程序7】
题目:输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。

import java.util.Scanner;

public class Test7 {
	public static void main(String[] args) {
		@SuppressWarnings("resource")
		Scanner sc = new Scanner(System.in);
		System.out.println("请输入一行字符:");
		String s = sc.nextLine();
		int character = 0, digital = 0;
		int blank = 0, other = 0;
		char[] ch = null;
		ch = s.toCharArray();//将字符串对象中的字符转换为一个字符数组
		for (int i = 0; i < ch.length; i++) {
			if (Character.isLetter(ch[i])) {//字符是否为字母
				character++;
			}else if (Character.isDigit(ch[i])) {//字符是否为数字
				digital++;
			}else if(ch[i] == ' ') {//空格
				blank++;
			}else {//其他
				other++;
			}
		}
		System.out.println("数字个数: " + digital);
		System.out.println("英文字母个数: " + character);
		System.out.println("空格个数: " + blank);
		System.out.println("其他字符个数:" + other);
	}
}

【程序8】
题目:求s=a+aa+aaa+aaaa+aa…a的值,其中a是一个数字。例如2+22+222+2222+22222(此时共有5个数相加),几个数相加有键盘控制。

import java.util.Scanner;

public class Test8 {
	public static void main(String[] args) {
		long a,sum = 0;
		int i = 0;
		@SuppressWarnings("resource")
		Scanner s = new Scanner(System.in);
		System.out.print("输入数字a的值: ");
		a = s.nextInt();
		System.out.print("输入相加的项数:");
		int n = s.nextInt();
		while (i < n) {
			sum = sum + a;
			a = a * 10 + a;
			i++;
		}
		System.out.println(sum);
	}
}

【程序9】
题目:一个数如果恰好等于它的因子之和,这个数就称为 "完数 "。例如6=1+2+3.编程;找出1000以内的所有完数。

public class Test9 {
	// 完数等于它的因子之和
	// 分解合数时得到的质数
	//一个自然数的所有的真因子(即除了自身以外的约数)的和恰好等于它本身
	/**
	 * 	6=1+2+3 
		28=1+2+4+7+14
		496=1+2+4+8+16+31+62+124+248
		8128=1+2+4+8+16+32+64+127+254+508+1016+2032+4064
	 * @param args
	 */
	public static void main(String[] args) {
		System.out.println("1到1000之间的所有完数:");
		for (int i = 1; i < 1000; i++) {// 遍历1000以内的所有整数
			int t = 0;
			for (int j = 1; j <= i / 2; j++) {
				if (i % j == 0) {// 满足是i的因子,就累加 
					t = t + j;
				}
			}
			if(t == i) {// 满足因子之和等于i就打印该完数 
				System.out.print(i+"  ");
			}
		}
	}
}

【程序10】
题目:一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在第10次落地时,共经过多少米?第10次反弹多高?

public class Test10 {
	public static void main(String[] args) {
		double h = 100, length = 100;
		for (int i = 1; i < 11; i++) {
			length = length + h;
			h = h / 2;
		}
		System.out.println("第10次,经过路程:" + length);
		System.out.println("第10次,反弹高度:" + h / 2);
	}
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

java编程题练习2 的相关文章

随机推荐

  • Linux 软件包管理常用命令

    安装软件包 apt get install packagename 删除软件包 apt get remove packagename 更新软件包列表 apt get update 升级有可用更新的系统 xff08 慎用 xff09 apt
  • flask框架初学-11-解决跨域问题

    在前面的学习中 xff0c 我们都是在本地起服务 xff0c 再在本地访问资源及界面 xff0c 但是实际当中都是开启多台服务器 xff0c 提供给局域网外的用户访问 这就牵涉到了跨域问题 xff0c 跨域问题来源于同源策略 xff0c 同
  • CSP-序列查询新解(C++简单易懂)

    题目背景 上一题 序列查询 中说道 xff1a A 61 A0 A1 A2 An 是一个由 n 43 1 个 0 N 范围内整数组成的序列 xff0c 满足 0 61 A0 lt A1 lt A2 lt lt An lt N 基于序列 A
  • 九、51单片机之直流电机驱动

    目录 1 什么是电机 2 常见电机 2 1 交流电机 2 2 交流电机补充 可跳过 2 3 直流电机 2 4 步进电机 伺服电机 3 直流电机驱动 1 什么是电机 1 电机的全称是电动机 xff0c 把电能转换成动能的一种电器 2 外观 2
  • 【Linux】 Linux下查询CPU、内存、硬盘、服务器型号、出厂日期

    一 查看CPU 1 1 查看CPU个数 cat span class token operator span proc span class token operator span cpuinfo span class token oper
  • 1.5 字符

    输入 输出 getchar putchar 1 5 1 文件复制 include lt stdio h gt 将输入复制到输出 xff1b 版本1 main int c c 61 getchar while c 61 EOF putchar
  • docker基础学习入门(六)------ DockerFile解析

    DockerFile是什么 Dockerfile是用来构建Docker镜像的构建文件 xff0c 是由一系列命令和参数构成的脚本 构建三步骤 xff1a 编写Dockerfile文件docker builddocker run 构建的文件什
  • mysql小练习

    设教学数据库Education有三个关系 xff1a 学生关系S xff08 SNO xff0c SNAME xff0c AGE xff0c SEX xff0c SDEPT xff09 xff1b 学系关系SC xff08 SNO xff0
  • C++ 快速幂取模运算理解

    C 43 43 快速幂取模运算理解 概念非递归方法原理代码实例 递归方法原理代码实例 概念 快速幂运算也叫反复平方法 顾名思义 xff0c 算法就蕴含在名字中 非递归方法 原理 假设要求 x 2 x 2 x 2
  • 01迷宫(洛谷)

    题目描述 有一个仅由数字 000 与 111 组成的 n nn times nn n 格迷宫 若你位于一格0上 xff0c 那么你可以移动到相邻 444 格中的某一格 111 上 xff0c 同样若你位于一格1上 xff0c 那么你可以移动
  • VSCode + Latex +Texlive 编译 biber格式参考文献时 VSCode的配置方法

    34 editor fontSize 34 17 34 files autoSave 34 34 onFocusChange 34 34 latex workshop showContextMenu 34 true 34 latex wor
  • 更换国内镜像源进行pip安装【附带国内镜像源】

    Linux中当我们需要安装某个模块时 xff08 比如tensorflow2 0 0 xff09 xff0c 常见有三种方法 xff1a pip install tensorflow 61 61 2 0 0pip install https
  • C/C++中如何遍历枚举类型?

    在C 43 43 中 xff0c 写一段代码 xff0c 把某个enum中的所有元素放入到vector中 xff0c 方便遍历 假设有以下的枚举类型 xff1a span class token comment c 43 43 span s
  • 201609-3 炉石传说

    201609 3 炉石传说 题意描述 本题要求我们去模拟一款游戏的运行 xff0c 游戏分为双方 轮流操作 操作共有三种形式 summon attack end 输入输出格式 输入 n 接下来是 n 个操作 每个操作由字符串区分 后面是操作
  • 超详细Windows10/Windows11 子系统(WSL2)安装Ubuntu20.04(带桌面环境)+CUDA11.3+pytorch1.8.1+pycharm

    超详细Windows10 Windows11 子系统 xff08 WSL2 xff09 安装Ubuntu20 04 xff08 带桌面环境 xff09 user zhaowei的博客 CSDN博客 wsl 桌面环境 目录前言在Windows
  • 洛谷_P1825 [USACO11OPEN]Corn Maze S(尚贤)

    题目 xff1a https www luogu com cn problem P1825 span class token macro property span class token directive keyword include
  • 从知名软件提取出的神器,吊打一众付费

    前言 现在的软件功能虽然越更新越多 xff0c 但也是越来越臃肿了 xff0c 不仅占内存 启动慢 xff0c 老更新也怪麻烦的 你们应该也有过因为某个小功能挺好用而不忍心卸载整款软件的情况吧 今天给大家分享几款从知名软件中提取出来的小工具
  • Ubuntu 设置网络代理的一些配置

    因公司需求 xff0c 连接网络必须使用代理设置连接网络 xff0c 这里给大家分享一下我的配置步骤 xff01 如果以下这些不符合你的需求 xff1a 来看这个 xff1a ubuntu 内网搭建服务器的一些配置 xff0c 完美解决ht
  • Linux上git+gitee的基本使用

    目录 1 git 2 gitee 3 本地仓库建立和git基本使用 1 远程仓库同步到本地仓库 xff1a 2 提交本地仓库到远程仓库进行更新 如在本地代码仓库中新建了test1 txt和test2 txt文件或者对文件内容进行了修改 xf
  • java编程题练习2

    程序6 题目 xff1a 输入两个正整数m和n xff0c 求其最大公约数和最小公倍数 在循环中 xff0c 只要除数不等于0 xff0c 用较大数除以较小的数 xff0c 将小的一个数作为下一轮循环的大数 xff0c 取得的余数作为下一轮