学点Java打小工——Day2Day3一点作业
1 猜数字(10次机会)
随机生成[1,1000]的一个数,输入你猜的数程序会给出反馈,直到猜对或次数用尽(10次)。
//猜数字 10次机会@Testpublic void guessNumber() {Random random = new Random();// [0, 1000) + 1// [1, 1000]int num = random.nextInt(1000) + 1;Scanner scanner = new Scanner(System.in);int cnt = 10;int num_guess;while (cnt > 0) {System.out.println("猜吧!请输入你猜的数字: ");num_guess = scanner.nextInt();System.out.println("你猜的数字是: " + num_guess);if (num_guess > num) {System.out.println("太大了");cnt--;} else if(num_guess < num) {System.out.println("太小了");cnt--;} else {System.out.println("恭喜你,猜对了");break;}}if (cnt == 0) {System.out.println("次数用尽,猜数失败");}}
2 打印99乘法表(双重循环)
双重for循环:
外层循环控制行数,数一下有几行就能确定外层循环。
内层循环控制列数,这一行打印多少个,到底要打印多少个要找出和当前行之间的一个关系。
//打印99乘法表@Testpublic void print99Table() {for (int i = 1; i <= 9; i++) {for (int j = 1; j <= i; j++) {System.out.print(j + "×" + i + "=" + (i * j));if(j != i) {System.out.print(" ");}}System.out.println();}}
做这个时候死去的上机题突然攻击我,控制了下每行最后一个空格不输出
3 判断闰年
也有收获,之前写的时候逻辑有一点点混乱,这次搞清楚本身其实可以拆成两个条件:
①能被4整除但不能被100整除
②能被400整除
有点数学容斥原理那味儿(死去的高中数学)
@Testpublic void judgeLeapYear() {System.out.println("请输入你要查询的年份: ");Scanner scanner = new Scanner(System.in);int year_in = scanner.nextInt();if ((year_in % 4 == 0 && year_in % 100 != 0) || (year_in % 400 == 0)) {System.out.println(year_in + "年是闰年");return true;} else {System.out.println(year_in + "年不是闰年");return false;}}
4 交换数字
老生常谈了
@Testpublic void exchangeNumber() {Scanner scanner = new Scanner(System.in);System.out.println("请输入第一个数: ");int num1 = scanner.nextInt();System.out.println("请输入第二个数: ");int num2 = scanner.nextInt();System.out.println("交换前: num1 = " + num1 + "\t" + "num2 = " + num2);int temp = num1;num1 = num2;num2 = temp;System.out.println("交换后: num1 = " + num1 + "\t" + "num2 = " + num2);}
嗯,老师还提了一嘴可以有很多方法,我确实只知道这一种。随便一搜确实有很多种
链接1
链接2
5 收银台
编写一个收银台收款程序:
定义输入----单价、数量、用户输入金额
定义输出----应收金额、找零
使用double类型变量 scanner.nextDouble();
当总价>=500时候打八折
考虑程序出现异常的情况,如:收款金额小于应收金额
若收款金额大于等于应收金额,则计算找零后输出
若收款金额小于应收金额,输出错误信息。
这个我写得还挺“长”的,主要是有些信息执行完在控制台不显示,我又加了打印
//收银台@Testpublic void recvMoney() {int cnt;double price, total, payment, change;Scanner scanner = new Scanner(System.in);System.out.print("请输入商品单价: ");price = scanner.nextDouble();System.out.println(price);System.out.print("请输入商品数量: ");cnt = scanner.nextInt();System.out.println(cnt);System.out.print("请付款: ");payment = scanner.nextDouble();System.out.println(payment);total = price * cnt;if (total >= 500) {System.out.println("商品总价超过500元, 给您打八折!");total *= 0.8;}if (payment < total) {System.out.println("对不起, 您的钱不够");} else {change = payment - total;System.out.println("找您" + String.format("%.2f", change));}}
6 打印直角三角形
输出以下结构:
1
12
123
1234
12345
//输出直角三角形数@Testpublic void printRightTriangle() {for (int i = 1; i <= 5; i++) {for (int j = 1; j <= i; j++) {System.out.print(j);}System.out.println();}}
7 打印正三角形/倒三角形
public void printEquilateralTriangle(int n) {int m;for (int i = 1; i <= n; i++) {for (int j = 1; j <= n - i; j++) {System.out.print(' ');}m = 2 * (i - 1) + 1;for (int j = 1; j <= m; j++) {System.out.print('*');}System.out.println();}}public void printInvertedTriangle(int n) {int m;for (int i = n; i >= 1; i--) {for (int j = 1; j <= n - i; j++) {System.out.print(' ');}m = 2 * (i - 1) + 1;for (int j = 1; j <= m; j++) {System.out.print('*');}System.out.println();}}//打印正三角/倒三角形@Testpublic void printTriangle() {Scanner scanner = new Scanner(System.in);System.out.print("请输入三角形阶数: ");int num = scanner.nextInt();System.out.println(num);System.out.print("请输入你要打印的三角形类型(1 正三角形; 2 倒三角形): ");int flag = scanner.nextInt();System.out.println(flag);int n = num;int m;if (flag == 1) {printEquilateralTriangle(n);} else if (flag == 2) {printInvertedTriangle(n);} else {System.out.println("非法输入 ");}}
分开写了两个方法然后调用,这样比较舒服
8 求奇数偶数和
计算1-100以内所有奇数的和以及所有偶数的和,分别打印出来
@Testpublic void printSum() {int sum_odd = 0;int sum_even = 0;for (int i = 1; i <= 100; i++) {if(i % 2 == 1) {sum_odd += i;}else {sum_even += i;}}System.out.println("sum_odd = " + sum_odd);System.out.println("sum_even = " + sum_even);}
9 输出数字
用for循环输出1—1000之间能被5整除的数,且每行输出3个
@Testpublic void printModFive() {int cnt = 0;for (int i = 1; i <= 1000; i++) {if(i % 5 == 0) {System.out.print(i);cnt++;if(cnt % 3 != 0) {System.out.print(' ');}else {cnt = 0;System.out.println();}}}}
10 计算阶乘
计算9的阶乘
@Testpublic void printFactorial() {int ans = 1;for(int i = 1; i <= 9; i++) {ans *= i;}System.out.println(ans);}
老师说还能用别的方法,我想到的是大数阶乘,那年暑假集训一道大数阶乘我做了一个晚自习。。。。
大数阶乘1
大数阶乘2
其实他想说的是递归啦,那其实没啥本质区别了,能做的数还是有限的,不过确实算个进阶写法。
后边再补吧,这周要叫开题报告、文献综述和外文翻译。想想就难受
相关文章:

学点Java打小工——Day2Day3一点作业
1 猜数字(10次机会) 随机生成[1,1000]的一个数,输入你猜的数程序会给出反馈,直到猜对或次数用尽(10次)。 //猜数字 10次机会Testpublic void guessNumber() {Random random new Random();// [0, 1000) 1// [1, 1000]int num ra…...

【话题】2024年AI辅助研发趋势,有那些应用领域
大家好,我是全栈小5,欢迎阅读文章! 此篇是【话题达人】系列文章,这一次的话题是《2024年AI辅助研发趋势》 目录 背景概念实践医药领域汽车设计领域展望未来文章推荐 背景 随着人工智能技术的持续发展与突破,2024年AI辅…...
蓝桥杯——数组切分
数组切分 题目分析 这里要搞清楚一个点就是满足区间内数字是连续数字的区间有什么样的特点,既然数字连续重新排列后的数字为n,n1,n2,n3,n4,…nlen,则最大数字和最小数字之差恰好是区间长度减1,即nlen-nlen,同样因为下标也是连续…...

【机器学习】进阶学习:详细解析Sklearn中的MinMaxScaler---原理、应用、源码与注意事项
【机器学习】进阶学习:详细解析Sklearn中的MinMaxScaler—原理、应用、源码与注意事项 这篇文章的质量分达到了97分,虽然满分是100分,但已经相当接近完美了。请您耐心阅读,我相信您一定能从中获得不少宝贵的收获和启发~ …...

数据库是什么?数据库连接、管理与分析工具推荐
一、数据库是什么? 数据库是一种结构化的数据存储系统,用于有效地组织、存储和管理大量的数据。它是一个集中化的数据存储库,通常由一个或多个数据表组成,每个数据表包含多个行和列,用于存储特定类型的数据。数据表中…...

【C#算法实现】可见的山峰对数量
文章目录 前言一、题目要求二、算法设计及代码实现2.1 算法思想2.2 代码实现 前言 本文是【程序员代码面试指南(第二版)学习笔记】C#版算法实现系列之一,用C#实现了《程序员代码面试指南》(第二版)栈和队列中的可见的…...

Selenium 隐藏浏览器指纹特征的几种方式
文章转载于:https://mp.weixin.qq.com/s/sXRXwMDqekUHfU2SnL-PYg 我们使用 Selenium 对网页进行爬虫时,如果不做任何处理直接进行爬取,会导致很多特征是暴露的 对一些做了反爬的网站,做了特征检测,用来阻止一些恶意爬虫…...
k8s发布nacos-server,nodeport配置注意事项
k8s发布nacos-server注册不上问题 问题描述:分析过程: 问题描述: k8s发布nacos-server做服务公用使用,nodeport暴漏服务给客户端注册, nacos:端口 8848:30601 9848:30701 分析过程:…...

伪分布式Spark集群搭建
一、软件环境 软 件 版 本 安 装 包 VMware虚拟机 16 VMware-workstation-full-16.2.2-19200509.exe SSH连接工具 FinalShell Linux OS CentOS7.5 CentOS-7.5-x86_64-DVD-1804.iso JDK 1.8 jdk-8u161-linux-x64.tar.gz Spark 3.2.1 spark-3.2.1-bin-…...

Android 监听卫星导航系统状态及卫星测量数据变化
源码 package com.android.circlescalebar;import androidx.annotation.NonNull; import androidx.appcompat.app.AppCompatActivity; import androidx.core.app.ActivityCompat; import androidx.core.content.ContextCompat; import android.Manifest; import android.conte…...

鸿蒙培训开发:就业市场的新热点~
金三银四在即,随着春节假期结束,各行各业纷纷复工复产,2024年的春季招聘市场也迎来了火爆的局面。最近发布的《2024年春招市场行情周报(第一期)》显示,尽管整体就业市场仍处于人才饱和状态,但华…...

【C++】string的底层剖析以及模拟实现
一、字符串类的认识 C语言中,字符串是以\0结尾的一些字符的集合,为了操作方便,C标准库中提供了一些str系列的库函数, 但是这些库函数与字符串是分离开的,不太符合OOP的思想,而且底层空间需要用户自己管理&a…...

Unity的PICO项目基础环境搭建笔记(调试与构建应用篇)
文章目录 前言一、为设备开启开发者模式1、开启PICO VR一体机。前往设置>通用>关于本机>软件版本号2、一直点击 软件版本号 ,直到出现 开发者 选项3、进入 开发者模式,打开 USB调试,选择 文件传输 二、实时预览应用场景1、下载PC端的…...

电脑远程桌面选项变成灰色没办法勾选怎么办?
有些人在使用Windows系统自带的远程桌面工具时,会发现系统属性远程桌面选项卡中勾选启用“允许远程连接到此计算机”。 导致此问题出现的原因主要是由于组策略或者注册表设置错误造成的。 修复远程桌面选项变灰的两种方法! 方法一:设置本地组…...

2024.3.14
1.成员函数版本实现算术运算符的重载,全局函数版本实现算术运算符的重载 #include <iostream>using namespace std;class Room {friend const Room operator-(const Room &a,const Room &b); private:string a;int b; public:Room(){}Room(string a,int b):a(a)…...

chatGPT的耳朵!OpenAI的开源语音识别AI:Whisper !
语音识别是通用人工智能的重要一环!可以说是AI的耳朵! 它可以让机器理解人类的语音,并将其转换为文本或其他形式的输出。 语音识别的应用场景非常广泛,比如智能助理、语音搜索、语音翻译、语音输入等等。 然而,语音…...

C语言冒泡排序
冒泡排序是一种简单的排序算法,通过重复遍历要排序的数列,依次比较两个相邻的元素,如果它们的顺序错误则交换它们。这个过程会重复进行,直到没有相邻的元素需要交换,也就是数列已经排序完成。 冒泡排序的名字来源于其工…...
vue2 elementui 封装一个动态表单复杂组件
封装一个动态表单组件在 Vue 2 和 Element UI 中需要考虑到表单字段的动态添加、删除以及验证等复杂功能。下面是一个简单的例子,展示如何创建一个可以动态添加和删除字段的表单组件。 首先,你需要安装并引入 Element UI: bash 复制 npm in…...

基于智慧灯杆的智慧城市解决方案(2)
功能规划 智慧照明功能 智慧路灯的基本功能仍然是道路照明, 因此对照明功能的智慧化提升是最基本的一项要求。 对道路照明管理进行智慧化提升, 实施智慧照明, 必然将成为智慧城市中道路照明发展的主要方向之一。 智慧照明是集计算机网络技术、 通信技术、 控制技术、 数据…...

「Paraverse平行云」亮相HKSTP OPENHOUSE活动
🚀11月7日,「Paraverse平行云」参展香港科学园HKSTP一年一度的Open House活动! ✨ 众多专家、同行与我们驻足深入交流,探索实时云渲染解决方案LarkXR在在数字人、数字孪生、建筑信息模型(BIM)、3D建模、建筑…...

Vue3 + Element Plus + TypeScript中el-transfer穿梭框组件使用详解及示例
使用详解 Element Plus 的 el-transfer 组件是一个强大的穿梭框组件,常用于在两个集合之间进行数据转移,如权限分配、数据选择等场景。下面我将详细介绍其用法并提供一个完整示例。 核心特性与用法 基本属性 v-model:绑定右侧列表的值&…...
FastAPI 教程:从入门到实践
FastAPI 是一个现代、快速(高性能)的 Web 框架,用于构建 API,支持 Python 3.6。它基于标准 Python 类型提示,易于学习且功能强大。以下是一个完整的 FastAPI 入门教程,涵盖从环境搭建到创建并运行一个简单的…...
Objective-C常用命名规范总结
【OC】常用命名规范总结 文章目录 【OC】常用命名规范总结1.类名(Class Name)2.协议名(Protocol Name)3.方法名(Method Name)4.属性名(Property Name)5.局部变量/实例变量(Local / Instance Variables&…...

全球首个30米分辨率湿地数据集(2000—2022)
数据简介 今天我们分享的数据是全球30米分辨率湿地数据集,包含8种湿地亚类,该数据以0.5X0.5的瓦片存储,我们整理了所有属于中国的瓦片名称与其对应省份,方便大家研究使用。 该数据集作为全球首个30米分辨率、覆盖2000–2022年时间…...
【RockeMQ】第2节|RocketMQ快速实战以及核⼼概念详解(二)
升级Dledger高可用集群 一、主从架构的不足与Dledger的定位 主从架构缺陷 数据备份依赖Slave节点,但无自动故障转移能力,Master宕机后需人工切换,期间消息可能无法读取。Slave仅存储数据,无法主动升级为Master响应请求ÿ…...

【开发技术】.Net使用FFmpeg视频特定帧上绘制内容
目录 一、目的 二、解决方案 2.1 什么是FFmpeg 2.2 FFmpeg主要功能 2.3 使用Xabe.FFmpeg调用FFmpeg功能 2.4 使用 FFmpeg 的 drawbox 滤镜来绘制 ROI 三、总结 一、目的 当前市场上有很多目标检测智能识别的相关算法,当前调用一个医疗行业的AI识别算法后返回…...
【生成模型】视频生成论文调研
工作清单 上游应用方向:控制、速度、时长、高动态、多主体驱动 类型工作基础模型WAN / WAN-VACE / HunyuanVideo控制条件轨迹控制ATI~镜头控制ReCamMaster~多主体驱动Phantom~音频驱动Let Them Talk: Audio-Driven Multi-Person Conversational Video Generation速…...

CVE-2020-17519源码分析与漏洞复现(Flink 任意文件读取)
漏洞概览 漏洞名称:Apache Flink REST API 任意文件读取漏洞CVE编号:CVE-2020-17519CVSS评分:7.5影响版本:Apache Flink 1.11.0、1.11.1、1.11.2修复版本:≥ 1.11.3 或 ≥ 1.12.0漏洞类型:路径遍历&#x…...

【VLNs篇】07:NavRL—在动态环境中学习安全飞行
项目内容论文标题NavRL: 在动态环境中学习安全飞行 (NavRL: Learning Safe Flight in Dynamic Environments)核心问题解决无人机在包含静态和动态障碍物的复杂环境中进行安全、高效自主导航的挑战,克服传统方法和现有强化学习方法的局限性。核心算法基于近端策略优化…...

排序算法总结(C++)
目录 一、稳定性二、排序算法选择、冒泡、插入排序归并排序随机快速排序堆排序基数排序计数排序 三、总结 一、稳定性 排序算法的稳定性是指:同样大小的样本 **(同样大小的数据)**在排序之后不会改变原始的相对次序。 稳定性对基础类型对象…...