Scanner类的使用:

​ 导入Scanner包,new Scanner对象,记得调用System.in参数,调用对应next方法实现键盘录入。

import java.util.Arrays;
import java.util.Scanner; /**
* 键盘录入:
* 键盘录入三个整数数值,然后比较三个数中的值
*/ public class ScannerTest {
public static void main(String[] args) {
int[] ints=new int[3];
Scanner sc=new Scanner(System.in);
for(int i=0;i<3;i++)
{
int num=sc.nextInt();
ints[i]=num;
for(int j=0;j<i;j++)
{
if(ints[j]<ints[i])
{
int temp=ints[j];
ints[j]=ints[i];
ints[i]=temp;
}
}
}
for(int i=0;i<3;i++)
System.out.println(ints[i]);
}
}

java 中对类的定义:

       java 本身是面向对象的语言,如果需要使用java去开发一个软件
那么,软件中每一个模块都是一个个体,每一个个体会拆分为很多单元,
每个单元本身是一个模糊的概念,针对这一的一个概念,我们一般用类
去定义,然后在具体执行的时候,需要让模块之间互相协作,正常的去
模拟现实生活中的场景的时候,就需要创建这个类所对应的实例!

用new新建数组

int[] ints={};//这样直接用{}初始相当于ints为空 抛出数组越界异常

int[] ints=new int[3];//相当于创建了一长度为3的整形数组

方法

//用于键入三个整形数并求和
public class getSum {
public static void main(String[] args) {
int[] ints=new int[3];
Scanner scanner=new Scanner(System.in);
for(int i=0;i< ints.length;i++)
{
ints[i]=scanner.nextInt();
}
System.out.println(sum(ints));
}
public static int sum(int[] ints)
{
int sum=0;
for(int i=0;i< ints.length;i++)
{
sum+=ints[i];
}
return sum;
}
}

​ 方法声明为静态static方法,在主函数中可以直接调用,如果方法并非static方法,要在主函数中调用,必须先定义一个该类对象,通过对象调用方法求和。

方法的递归与重载

​ 递归是方法自己调用自己,递归会严重损耗系统的资源,尽量避免使用递归

​ 方法重载是方法的方法名相同,但是方法的参数列表不同,参数列表不同包括参数的个数不同、个数相同但是参数的类型不同。

数组

1.数组的创建

数组是引用数据类型,可以通过new的方式创建数组

创建数组的两种方式

int[] ints1=new int[10];//创建后不赋值 整型默认值为0
int ints2[]=new int[10];

2.数组的foreach遍历方法

//创建引用类型数组
String[] strings=new String[5];//创建后不赋值 字符型默认值为null
strings[0] = "hello";
strings[1] = "hello";
strings[2] = "world";
strings[3] = "hello";
strings[4] = "java";
//统计hello这个字符串出现的次数
//equals()是字符串的常用方法,判断字符串是否完全相同
int num=0;
//foreach 遍历
//for(存放数据的数据类型 遍历的每一项: 容器对象 )
for(String str : strings)
{
if(str.equals("hello"))
{
num++;
}
}
System.out.println("hello出现的次数:"+num);

字符串常用方法

1、str.equals() 判断字符串是否完全匹配

//str.equals() 判断字符串是否完全匹配
System.out.println(str.equals("hello world"));

2、str.contains() 判断是否包含某一字符串

//str.contains() 判断是否包含某一字符串
System.out.println(str.contains("hello"));

3、str.substring(int beginIndex) //表示从String第一个字符 即下标0开始切割到beginIndex

str.substring(int beginIndex,int endIndex)//从下标beginIndex开始,到endIndex-1结束 比如(6,11)得到world

// 字符串切割
System.out.println(str.substring(1));
System.out.println(str.substring(6,11));

4、str.toLowerCase() 大写转小写

String str3="hELLO world";str3.toLowerCase()

5、str.length() 求长度

str.length()

6、str.endsWith(String suffix) 判断是否以某字符串结尾

str.endsWith("world")

7、str.split() 字符串的分割 返回一个数组

String[] strings=str.split(" ");

8、str.toCharArray() 字符串转出字符数组

char[] chars=str.toCharArray();

9、str.replace() 将字符串中target以replacement字符串替换

String str2=str.replace("world","java");

10、str.indexOf(char ch) 返回第一次ch出现的地址

String str="abbcw";str.indexOf('w');//返回4str.indexOf('cw');//返回3

案例

​ 统计每个字符出现的个数

String str="这里是要统计的字符串";char[] chars=str.toCharArray();int[]  num=new int[chars.length];String str2="";//记录单个字符int i=0;for (char c:chars){    String tempstr=""+c;    if(!str2.contains(tempstr))//如果不包含    {        str2=str2+c;        num[i]++;        i++;    }    else    {        num[str2.indexOf(c)]++;    }}char[] chars1=str2.toCharArray();for(int j=0;num[j]!=0;j++) {    System.out.println(chars1[j]+"出现了"+num[j]+"次");}

为了统计每个字符出现的次数,可以用一个整型数组存放字符出现的次数,并且这里采用字符串存放单个字符,最后转换字符串为字符数组打印出来,这样可以利用字符串类的一些函数而避免多次for循环。

这种具有key和value类型的结构可以用集合中的hashmap来实现。

java Scanner类与String类的更多相关文章

  1. Java Object类 和 String类 常见问答 6k字+总结

    写在最前面 这个项目是从20年末就立好的 flag,经过几年的学习,回过头再去看很多知识点又有新的理解.所以趁着找实习的准备,结合以前的学习储备,创建一个主要针对应届生和初学者的 Java 开源知识项 ...

  2. java学习笔记之String类

    String类总结 String类概述: java.lang.String 类是字符串操作类 String类的常用构造方法: //1.直接赋值 String str= "hellojava& ...

  3. java问题解读,String类为什么是final的

    一.理解final 望文生义,final意为“最终的,最后的”,我理解为“不能被改变的”,它可以修饰类.变量和方法. 所以我是否可以理解为被它所修饰的类.变量和方法都不能被改变呢?答案是”是“,因为有 ...

  4. Java的常用类——Object类、String类

    Java的JDK中提供给我们很多封装好的类就是Java API,可以直接调用. Java 的API(API: Application(应用) Programming(程序) Interface(接口) ...

  5. C#中 StringBuilder类 与 String类的区别---(转)

      在找工作的时候,去了些公司,避免不了要面试和笔试.不过一般最起初的是笔试.我印象中有这样有一道题目:StringBuilder类与 String类的区别?那时候我不太清楚这两个类的区别,今天在看代 ...

  6. Hadoop: Text类和String类的比较

    一般认为Text类和String类是等价的,但二者之间其实存在着不小差别: 以<Hadoop权威指南>中的案例为例,给定字符串  String s = "\u0041\u00DF ...

  7. Java中的Scanner类和String类

    1:Scanner的使用(了解)    (1)在JDK5以后出现的用于键盘录入数据的类. (2)构造方法: A:讲解了System.in这个东西.            它其实是标准的输入流,对应于键 ...

  8. Java常用类之String类练习

    1.编程. 已知字符串:"this is a test of java". 按要求执行以下操作: (1) 统计该字符串中字母s出现的次数 (2) 取出子字符串"test& ...

  9. Java (六、String类和StringBuffer)

    Java String 类 字符串广泛应用 在Java 编程中,在 Java 中字符串属于对象,Java 提供了 String 类来创建和操作字符串. 创建字符串 // ==比较的是字符串在栈中存放的 ...

  10. 07 Object类,Scanner,Arrays类,String类,StringBuffer类,包装类

    Object类的概述:* A:Object类概述    * 类层次结构的根类    * 所有类都直接或者间接的继承自该类* B:构造方法    * public Object()    * 子类的构造 ...

随机推荐

  1. print spooler LPF 打印机漏洞

    打印机漏洞 该漏洞可以通过创建打印机驱动和端口,实现任意文件写入,用于提权或者写入后门. 打印机调用流程:client通过RPC调用server的spoolsv.exe,spoolsv.exe是sys ...

  2. C++/CLR 使用(VS2012,VS2013,VS2015)编写

    转载自:http://www.th7.cn/system/win/201509/129417.shtml VS2010以及以前的版本,创建项目时都可以在CLR下找到"Windows窗体应用程 ...

  3. diff算法深入一下?

    文章转自豆皮范儿-diff算法深入一下 一.前言 有同学问:能否详细说一下 diff 算法. 简单说:diff 算法是一种优化手段,将前后两个模块进行差异化比较,修补(更新)差异的过程叫做 patch ...

  4. 使用Servlet前Tomcat介绍

    虚拟目录的映射方式:让tomcat服务器自动映射tomcat服务器会自动管理webapps目录下的所有web应用,并把它映射成虚似目录.换句话说,tomcat服务器webapps目录中的web应用,外 ...

  5. 用例图示例:使用系统边界表示多个项目 / Using System Boundary to model Multiple Projects in Use Case Diagram

    什么是用例图? 用例是一种捕获系统功能需求的技术.用例描述了一个独立于实现细节的期望行为.用例的目标是捕获用户设想的所有系统级功能.从用户的角度来看,用例是关于系统应该做什么的.用例捕获系统利益相关者 ...

  6. Noip模拟84 2021.10.27

    以后估计都是用\(markdown\)来写了,可能风格会有变化 T1 宝藏 这两天老是会的题打不对,还是要细心... 考场上打的是维护\(set\)的做法,但是是最后才想出来的,没有维护对于是没有交. ...

  7. Noip模拟18 2021.7.17 (文化课专场)

    T1 导弹袭击(数学) 显然,我们要找到最优的A,B使得一组a,b优于其他组那么可以列出: $\frac{A}{a_i}+\frac{B}{b_i}<\frac{A}{a_j}+\frac{B} ...

  8. 21.10.14 test

    题目 WOJ5078 到 WOJ5081 T1 Problem A \(\color{green}{100}\) 由于每轮要选择尽量多的边删除,所以想到无向图的生成树,因为在生成树上再加一条边就会形成 ...

  9. Codeforces Round #742 (Div. 2)题解

    链接 \(A,B\)题签到,就完了. \(C\)题,考虑进位时多进一位,由于是隔一位进的,所以可以发现奇数位和偶数位是相互独立的,那么我们就把奇数位和偶数位单独拉出来组成数字例如:34789,我们单独 ...

  10. Hdu P1394 Minimum Inversion Number | 权值线段树

    题目链接 题目翻译: 约定数字序列a1,a2,...,an的反转数是满足i<j和ai>aj的数对(ai,aj)的数量. 对于给定的数字序列a1,a2,...,an,如果我们将第1到m个数字 ...