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

这篇具有很好参考价值的文章主要介绍了【蓝桥杯备赛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真的香,但是我们还是得熟悉这个环境,推荐大家下载下面这个最基础的版本

【蓝桥杯备赛Java组】语言基础|竞赛常用库函数|输入输出|String的使用|常见的数学方法|大小写转换,蓝桥杯,蓝桥杯,职场和发展,数据结构,算法,docker,容器,运维

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.定义一个方法包含以下语法:

【蓝桥杯备赛Java组】语言基础|竞赛常用库函数|输入输出|String的使用|常见的数学方法|大小写转换,蓝桥杯,蓝桥杯,职场和发展,数据结构,算法,docker,容器,运维

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) //返回指定索引的字符

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

【蓝桥杯备赛Java组】语言基础|竞赛常用库函数|输入输出|String的使用|常见的数学方法|大小写转换,蓝桥杯,蓝桥杯,职场和发展,数据结构,算法,docker,容器,运维


二、竞赛常用库函数

1.常见的数学方法

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

方法 返回值 功能
max(double a, double b) double a和b之间的最大值
min(double a, double b) double a和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和min
		for(int i=0;i<n;i++) {
			max = Math.max(f[i], max);
			min = Math.min(f[i], min);
		}
		//求absmax
		for(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);//adaddcd

        String 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);
        }
    }

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

【蓝桥杯备赛Java组】语言基础|竞赛常用库函数|输入输出|String的使用|常见的数学方法|大小写转换,蓝桥杯,蓝桥杯,职场和发展,数据结构,算法,docker,容器,运维文章来源地址https://www.toymoban.com/news/detail-810776.html

到了这里,关于【蓝桥杯备赛Java组】语言基础|竞赛常用库函数|输入输出|String的使用|常见的数学方法|大小写转换的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

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

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

相关文章

  • 蓝桥杯备赛 day 1 —— 递归 、递归、枚举算法(C/C++,零基础,配图)

    目录 🌈前言 📁 枚举的概念 📁递归的概念     例题: 1. 递归实现指数型枚举 2. 递归实现排列型枚举 3. 递归实现组合型枚举 📁 递推的概念    例题: 斐波那契数列 📁习题 1. 带分数 2. 反硬币 3. 费解的开关 📁 总结                  这篇文章主要是准备蓝桥杯竞

    2024年02月03日
    浏览(48)
  • 蓝桥杯备赛(Day5)——二叉树

    普通做法,二叉树一个节点包括结点的数值以及指向左右子节点的指针 在class Node中 在竞赛中,我们往往使用静态数组实现二叉树,定义一个大小为N的静态结构体数组,使用其来存储一棵二叉树。 使用静态数组时,对应的tree假如不是满二叉树,则应该使用-1或者0填补空缺,

    2024年02月09日
    浏览(48)
  • 蓝桥杯备赛|成绩统计|排列字母|纸张尺寸

    目录   1 成绩统计 题目描述 输入描述 输出描述 输入输出样例 示例 1.1 解题思路 1.2 AC_Code Python 标程 2 排列字母 问题描述 2.1 解题思路 2.2 AC_Code Python 标程 3 纸张尺寸 问题描述 输入格式 输出格式 样例输入1 样例输出1 样例输入 2 样例输出 2 运行限制 3.1 解题思路 3.2 AC_Code P

    2023年04月09日
    浏览(43)
  • 【AcWing】蓝桥杯备赛-深度优先搜索-dfs(1)

    目录 写在前面: 题目:92. 递归实现指数型枚举 - AcWing题库 读题: 输入格式: 输出格式: 数据范围: 输入样例: 输出样例: 解题思路: 代码: AC !!!!!!!!!! 写在最后: 距离蓝桥杯已经不足一个月了, 根据江湖上的传言, 蓝桥杯最喜欢考的是深度优先搜索和

    2024年02月03日
    浏览(55)
  • 蓝桥杯备赛 | 洛谷做题打卡day2

    ​ 题目来源:洛谷P2670 [NOIP2015 普及组] 扫雷游戏 NOIP2015 普及组 T2 扫雷游戏是一款十分经典的单机小游戏。在 n n n 行 m m m 列的雷区中有一些格子含有地雷(称之为地雷格),其他格子不含地雷(称之为非地雷格)。玩家翻开一个非地雷格时,该格将会出现一个数字——提示

    2024年01月16日
    浏览(62)
  • 蓝桥杯备赛 | 洛谷做题打卡day5

    题目描述 小 K 喜欢翻看洛谷博客获取知识。每篇文章可能会有若干个(也有可能没有)参考文献的链接指向别的博客文章。小 K 求知欲旺盛,如果他看了某篇文章,那么他一定会去看这篇文章的参考文献(如果他之前已经看过这篇参考文献的话就不用再看它了)。 假设洛谷

    2024年01月17日
    浏览(59)
  • 蓝桥杯备赛 | 洛谷做题打卡day4

    高精度加法,相当于 a+b problem, 不用考虑负数 。 分两行输入。 a , b ≤ 1 0 500 a,b leq 10^{500} a , b ≤ 1 0 500 。 输出只有一行,代表 a + b a+b a + b 的值。 样例输入 #1 样例输出 #1 样例输入 #2 样例输出 #2 学会利用新知,自己多试试并尝试积攒一些固定解答方案,debug,以下是我的

    2024年01月17日
    浏览(45)
  • 蓝桥杯备赛之动态规划篇——涂色问题(区间DP)

    2023第十四届蓝桥杯模拟赛第二期个人题解(Java实现) 2023第十四届蓝桥杯模拟赛第三期个人题解(Java实现) 蓝桥杯备赛之动态规划篇——背包问题 蓝桥杯真题——单词分析(Java实现) 😘😘 哈喽,大家好!这里是蓝桥杯系列文章的动态规划章节🔥🔥,今天要讲解的是区

    2024年01月23日
    浏览(48)
  • 开源语言大模型演进史:高质量基础模型竞赛

    本文是开源 LLM 发展史系列文章的第二部分。第一部分《 开源语言大模型演进史:早期革新 》回顾了创建开源 LLM 的最初尝试。本文将研究目前可用的最受欢迎的开源基础模型(即已进行预训练但尚未微调或对齐的语言模型)。 (本文作者为Rebuy公司AI总监、深度学习博士C

    2024年02月05日
    浏览(58)
  • Facebook Meta 以其最先进的基础语言模型 LLaMA 升温 AI 竞赛(含项目源码)

    Meta AI 已经进入了由大型语言模型 (LLM) 主导的 AI 竞赛,例如 OpenAI 的 ChatGPT、微软的 GPT-powered Bing 和谷歌的 Bard。Meta 首席执行官马克·扎克伯格 (Mark Zuckerberg) 在Facebook帖子中发布了这一消息:“今天我们发布了一种名为 LLaMA 的新型最先进的 AI 大型语言模型,旨在帮助研究人员

    2024年02月15日
    浏览(60)

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

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

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

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

二维码1

领取红包

二维码2

领红包