【蓝桥杯备赛Java组】语言基础|竞赛常用库函数|输入输出|String的使用|常见的数学方法|大小写转换

  • 🎥 个人主页:深鱼~
  • 🔥收录专栏:蓝桥杯
  • 🌄欢迎 👍点赞✍评论⭐收藏

目录

一、编程基础

1.1 Java类的创建

 1.2 Java方法

 1.3 输入输出

 1.4 String的使用

二、竞赛常用库函数

1.常见的数学方法

2.大小写转换


推荐

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站


一、编程基础

1.1 Java类的创建

1. 蓝桥杯Java 语言开发环境

JDK 1.8
Eclipse-java-2020-09
API 帮助文档(中文,chm格式)

所以我们要学会用Eclipse,虽然idea真的香,但是我们还是得熟悉这个环境,推荐大家下载下面这个最基础的版本

2.main()的方法的声明:public static void main(String args[ ]) (必须这么定义,这是Java的规范)

其中public static void 为类型,main为方法名,参数类型为String[ ] ,参数名为args只有这个参数名可以改,但是也不建议改

3.static关键字方便在没有创建对象的情况下进行调用(方法/变量),因为static修饰的成员变量和方法,从属于类

4.final修饰符:变量一旦被赋值后,不能被重新赋值(final通常和static一起用来创建类常量

5.Java的内置数据类型比C语言多了byte类型(8位)和boolean类型(只有两个取值,false和true,未初始化时默认的就是false


 1.2 Java方法

1.定义一个方法包含以下语法:

System.out.printIn( ):System是系统类,out是标准输出对象,printIn( )是一个方法

这句话的意思就是调用系统类System中的标准输出对象out中的方法printIn()

2.方法的重载:就是说一个类的两个方法具有相同的名字,但是参数列表不同(参数个数不同/顺序不同/类型不同都可以)

 3.算法中的常见方法:

(1)gcd(求两个整数x,y的最大公约数)

public static int gcd(int x,int y) {if(y==0) return x;return gcd(y,x%y);}

 思想:辗转相除法

举例:

a=28,b=21                                                     a=21,b=28

c=a%b=7(c!=0)                                      c=a%b=21(c!=0)

a=b=21;                                                         a=b=28

b=c=7;                                                         b=c=21(这时候a和b交换了)

c=a%b=0

直接输出b=7(最大公约数)

将上面递归代码转为循环的形式:

public static int gcd(int a,int b) {int c = 0;while(b!=0) {c = a%b;a = b;b = c;}return a;}

(2)Icm(求两个整数的最小公倍数)

public static int lcm(int x,int y) {return x*y/gcd(x,y);}

思路:x * y=这两个数的最大公约数 * 最小公倍数

(3)判断一个整数是否为质数

public static boolean isPrime(int x) {if(x==1) {return false;//1特殊,不是质数}for(int i=2;i<x;i++) {if(x%i==0)return false;}return true;}

 1.3 输入输出

1.输入方法(Scanner类):

(1)需要导入java.util包

(2)构造Scanner对象,参数为标准输入流System.in

2.Scanner类的9大输入方法

(1)nextBoolean(),nextInt(),nextLong(),nextByte(),nextFloat(),nextDouble(),nextShort()//接收基本数据类型

(2)next() //接收读取不带空格的字符串,遇到空格读取结束

(3)nextLine() //接收读取整段字符串,以Enter为结束符,可读取空格字符

3.输出方法

(1)System.out.print() //最常见的输出语句

(2)System.out.println() //和上面一个基本一样,区别就是执行后会换行

(3)System.out.printf() //跟C语言一样的输出,通过格式化文本和参数列表输出

eg:结果保留两位小数: System.out.printf("%.2f",13.14520);  //13.15

简单真题实战:A+B 问题【OJ 示例题目】 - 蓝桥云课


 1.4 String的使用

1.String类的特点:

(1)创建后不能改

(2)new方式创建的地址不同 eg:String str = new String()

(3)双引号内容相同,地址相同 eg:String str ="abc"

2.StringBuilder类和String类的区别:

(1)String的值不可变,StringBuilder的值是可变的

(2)String适于少量的字符串的情况;StringBuilder适于需要对字符串进行修改的情况

3.String常用方法:

(1)常见的两种构造方法:

String str = new String();//创建一个null字符串对象String str = new String("code");//创建一个为code的字符串对象

(2)char charAt(int index) //返回指定索引的字符

(3)int compareTo(Object o) //把这个字符串和另一个对象比较。大于返回1,等于返回0,小于返回-1

(4)String concat(String str) //将指定字符串连接到此字符串的结尾,并赋给新的字符串

(5)boolean equals(String str) //将此字符串与指定的字符串比较

(6)int indexOf(String str) //返回指定子字符串在此字符串中第一次出现处的索引。没出现返回-1

(7)int length()//返回此字符串的长度

(8)String substring(int beginIndex,int endIndex) //返回一个新字符串,它是此字符串的一个子字符串(注意是左闭右开)

(9)char[] toCharArray() //将此字符串转换为一个新的字符数组

(10)boolean isEmpty() //判断字符串是否为空

 4.StringBuilder常见方法

(1)常见的构造方法:

StringBuilder str = new StringBuilder();//创建一个null字符串对象

(2)void append(Object obj) //追加 Object参数的字符串表示形式

(3)int indexOf(Strring str) //返回指定子字符串第一次出现的字符串中的索引.

(4)StringBuilder reverse() //返回一个StringBuilder的对象,为该对象的反转并赋值给一个字符串

(5)boolean isEmpty() //判断字符串是否为空

(6)int charAt(int index) //返回指定索引的字符

简单真题实战:数字反转 - 蓝桥云课


二、竞赛常用库函数

1.常见的数学方法

使用时都要加上Math.(M要大写)

方法返回值功能
max(double a, double b)doublea和b之间的最大值
min(double a, double b)doublea和b之间的最小值
abs(int a)int返回参数的绝对值
sqrt(double a)double取a的平方根,其中a不能为负数
cbrt(double a)double取a的立方根
pow(double a, double b)double取a的b次方

例题:输入n个整数 a1,a2,a3....an,求这n个数的最大值max,最小值min,以及 ai-aj绝对值的最大值(i!=j)(n<=1000.ai<=1000)
实例:
输入:5
1 2 3 4 5
输出:5 1 4 

思路:

(1)先定义max和absmax为0,min为 Integer.MAX_VALUE

(2)单次循环遍历用max和min方法求最大值和最小值

(3)双重循环求差值,并用abs方法求差的绝对值;再用max方法求绝对值的最大值

import java.util.*;
public class Main {public static void main(String [] args) {//输入Scanner s = new Scanner(System.in);int n = s.nextInt();int []f = new int [n];int max = 0, min = Integer.MAX_VALUE, absmax = 0;for(int i=0;i<n;i++) {f[i] = s.nextInt();}//求max和minfor(int i=0;i<n;i++) {max = Math.max(f[i], max);min = Math.min(f[i], min);}//求absmaxfor(int i=0;i<n;i++) {for(int j=0;j<n;j++) {if(i==j) continue;absmax = Math.max(Math.abs(f[i]-f[j]), absmax);}}//输出System.out.print(max+" "+min+" "+absmax);}}

2.大小写转换

(1)方法转换

语法格式如下:

字符串名.toLowerCase() // 将字符串中的字母全部转换为小写,非字母不受影响

字符串名.toUpperCase() // 将字符串中的字母全部转换为大写,非字母不受影响

public static void main(String[] args) {String str = "ADaddcD";String str1 = str.toLowerCase();//大写字母转换为小写字母,非字母字符不变System.out.println(str1);//adaddcdString str2 = "adadcDAD";String str3 = str2.toUpperCase();//小写字母转为大写字母,非字母字符不变System.out.println(str2);//adadcDAD}

(2)异或转换

将一个字符串中的大写字母转换成小写字母,小写字母转换成大写字母:
一个字符a异或数字32就可以完成小写转换
实例:charA=a^32        char a=A^32

原理:a = 01100001 A = 01000001(大小写字母的二进制ASCII码只有第6位有所不同

public static void main(String[] args) {Scanner sc = new Scanner(System.in);String str = sc.next();for (int i = 0; i < str.length(); i++) {char x = str.charAt(i);if(x>='a'&&x<='z'||x>='A'&&x<='Z') {x^=32;}System.out.print(x);}}

本次内容就到此啦,欢迎评论区或者私信交流,觉得笔者写的还可以,或者自己有些许收获的,麻烦铁汁们动动小手,给俺来个一键三连,万分感谢 !

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

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

相关文章

邦芒支招:避免薪资谈崩的六个措施

对于求职者而言&#xff0c;我喜欢把回答薪资问题比喻成玩扑克牌&#xff0c;它的目标就是让招聘方先亮出底牌。其原因在于&#xff0c;正如詹姆斯察觉到的&#xff0c;一旦你暴露了具体的薪资数目&#xff0c;你就会陷入要价太高(或者太低)的境地。 以下这些小技巧也许能为…

函数传参之按值传递

定义&#xff1a;所有函数的参数都是按值传递的&#xff0c;这意味着函数外的值被会被赋值到函数内部的参数中&#xff0c;就像从一个变量赋值到另外一个变量一样 **原始值&#xff1a;那么久跟原始值变量的复制一样** **引用值&#xff1a;那么久跟引用值复制一样**变量有按值…

php基础学习之代码框架

一&#xff0c;标记 脚本标记&#xff08;已弃用&#xff09;&#xff1a;<script language"php"> php代码 </script> 标准标记&#xff1a;<?php php代码 ?> 二&#xff0c;基础输出语句 不是函数&#xff0c;…

国内比较好的sap实施商有哪些?

在当今数字化浪潮的推动下&#xff0c;企业的数字化转型已成为企业竞争力的关键因素。而在众多企业应用软件中&#xff0c;SAP&#xff08;系统应用和产品&#xff09;作为全球的企业资源规划&#xff08;ERP&#xff09;解决方案供应商&#xff0c;扮演着至关重要的角色。然而…

javascript设计模式-应用示例

事件工具类 /* addEvent: simplified event attachment */ function addEvent( obj, type, fn ) {if (obj.addEventListener) {obj.addEventListener( type, fn, false );EventCache.add(obj, type, fn);}else if (obj.attachEvent) {obj["e"typefn] fn;obj[typefn…

【WSL】[出现错误 2147944320 (0x80070780) (启动“ubuntu.exe”时)]

问题描述 在尝试启动 Windows Subsystem for Linux (WSL) 的 “ubuntu.exe” 时&#xff0c;可能会遇到以下错误&#xff1a; [出现错误 2147944320 (0x80070780) (启动“ubuntu.exe”时)]错误的截图如下&#xff1a; 原因分析 系统找不到指定的文件。在这种情况下&#xff…

Git提交 ssh: connect to host github.com port 22: Connection timed out解决方案

你们好&#xff0c;我是金金金。 场景 之前都是好好的&#xff0c;不知道今天为什么提交代码就这样了 排查 根据英文可以看出&#xff0c;ssh端口号被拒绝了&#xff0c;22号端口不行&#xff0c;那就换一个端口 造成error的原因 ssh端口被拒绝 解决 找到.ssh文件&#xff…

CLion调试Nodejs源码

【环境】 macOS node-v20.11.0源码 CLion 2023.3.2 【1】下载源码 https://nodejs.org/en/download/ 【2】编译源码 解压后的目录如下 进入解压后的目录进行编译 ./configure --debug make -C out BUILDTYPEDebug -j 4需要好久… 编译成功之后在node-v20.11.0目录下会有一个…

【Web实操11】定位实操_照片墙(无序摆放)

设置一个板块&#xff0c;将照片随意无序摆放在墙上&#xff0c;从而形成照片墙。本来效果应该是很唯美好看的&#xff0c;就像这种&#xff0c;但是奈何本人手太笨&#xff0c;只好设置能达到照片墙的效果就可。 代码如下&#xff1a; <!DOCTYPE html> <html lang&…

SpringBoot整理-Spring Boot配置

Spring Boot 的配置系统是其核心功能之一,旨在简化 Spring 应用的配置过程。Spring Boot 提供了一种灵活的方式来配置你的应用,无论是通过外部配置文件,环境变量,命令行参数还是在代码中直接配置。以下是关于 Spring Boot 配置的几个重要方面: 配置文件 application.prope…

JavaEE的MVC(Model-View-Controller)设计模式

JavaEE的MVC&#xff08;Model-View-Controller&#xff09;设计模式是一种用于组织和管理Web应用程序的架构模式。MVC模式将应用程序分为三个主要组件&#xff1a;模型&#xff08;Model&#xff09;、视图&#xff08;View&#xff09;和控制器&#xff08;Controller&#x…

binary_search_tree的介绍与实现(二叉搜索树精美图示详解哦)

二叉搜搜索树 引言二叉搜索树的介绍二叉搜索树的实现框架默认成员函数构造析构赋值重载 InsertR&#xff08;插入&#xff09;EraseR&#xff08;删除&#xff09;SearchR&#xff08;查找&#xff09; 源码概览总结 引言 在C语言部分&#xff0c;我们已经认识了树与二叉树的结…

【嵌入式经验积累】C语言实现傅里叶变换

文章目录 C 语言实现离散傅利叶变换&#xff08;DFT&#xff09;代码如下&#xff1a;C 语言实现快速傅利叶变换&#xff08;FFT&#xff09;&#xff0c;代码如下&#xff1a;分裂基快速傅利叶变换代码如下。实序列快速傅利叶变换&#xff08;一&#xff09;&#xff0c;代码如…

Nginx 实战指南

Nginx 是一款高性能的开源反向代理服务器,也可用作负载均衡器、Web服务器和缓存服务器。本实战指南将带你深入了解 Nginx 的安装、基础配置、高级配置、最佳实践以及性能调优。 步骤 1: 安装 Nginx Ubuntu sudo apt update sudo apt install nginx CentOS sudo yum insta…

python使用分治算法找出出现次数最多的数字

对于给定的一个长度为n的数组nums&#xff0c;需要找出起重工出现次数大于n/2向下取整的元素&#xff0c;假设给定的数组中一定存在符合给定要求的数&#xff0c;例如给定如下的例子&#xff1a; 添加图片注释&#xff0c;不超过 140 字&#xff08;可选&#xff09; 添加图片注…

docker使用http_proxy配置代理

钢铁知识库&#xff0c;一个学习python爬虫、数据分析的知识库。人生苦短&#xff0c;快用python。 在内网服务器中&#xff0c;docker经常需要下载拉取镜像&#xff0c;但由于没有网络要么只能手动导入镜像包&#xff0c;又或者通过http_proxy代理到其它服务器下载。 解决方法…

看书标记【R语言数据分析项目精解:理论、方法、实战 9】

看书标记——R语言 Chapter 9 文本挖掘——点评数据展示策略9.1项目背景、目标和方案9.1.1项目背景9.1.2项目目标9.1.3项目方案1.建立评论文本质量量化指标2.建立用户相似度模型3.对用户评论进行情感性分析 9.2项目技术理论简介9.2.1评论文本质量量化指标模型1.主题覆盖量2.评论…

FA-分配行重分配报错【APP-OFA-48313】

FA-重分配行报错 已存在行只能分多次转移调整 Ref1&#xff1a; APP-OFA-48313 You Cannot Create Identical Distribution Lines with Transfer (Doc ID 336894.1) APPLIES TO: Oracle Assets - Version 11.5.10.0 and later Information in this document applies to any…

Ubuntu20 服务器版磁盘扩容

Ubuntu20 服务器版磁盘扩容 Ubuntu20 服务器版磁盘不够用进可以使用fdisk命令对磁盘进行扩容 本案例中是基于vmware虚拟化环境下&#xff0c;ubuntu服务器按默认磁盘大小16G进行安装后&#xff0c;运行一段时间后发面/分区磁盘空间全部用完&#xff0c;导致服务无法正常运行。基…

计算机网络自顶向下Wireshark labs1-Intro

Wireshark labs1 实验文档&#xff1a;http://www-net.cs.umass.edu/wireshark-labs/Wireshark_Intro_v8.0.pdf 介绍 加深对网络协议的理解通常可以通过观察协议的运行和不断调试协议来大大加深&#xff0c;具体而言&#xff0c;就是观察两个协议实体之间交换的报文序列&…