Random
作用:
– 用于产生一个伪随机数
• 使用步骤(和Scanner类似)
– 导包
• import java.util.Random;
– 创建对象
• Random r = new Random();
– 获取伪随机数
• int number = r.nextInt(10);
• 产生的数据在0到10之间,包括0,不包括10。
• 括号里面的10是可以变化的,如果是100,就是0-100之间的数据
/**
* @author Lynn
* @create 2020-11-19-9:22
*/
//1.导入Random包
import java.util.Random;
public class TestRandom01 {
public static void main(String[] args) {
//2.创建Random对象
Random r=new Random();
//3.使用random对象
//返回int类型中的数据,范围就是int类型定义的范围之间
int a;
for(int i=1;i<10;i++){
a=r.nextInt();
System.out.println(a);
}
//取出某一范围整数 [0-54)=0...54
int b=r.nextInt(54);//返回包含0,不包含54的随机数
System.out.println(b);
}
}
/**
* @author Lynn
* @create 2020-11-19-9:32
*/
import java.util.Random;
import java.util.Scanner;
/**
* 猜数字小游戏案例
* * 系统产生一个1-100之间的随机数,请猜出这个数据是多少。
* * 分析:
* * A:系统产生一个随机数1-100之间的。
* * int number = r.nextInt(100) + 1;
* * B:键盘录入我们要猜的数据
* * 用Scanner实现
* * C:比较这两个数据(用if语句)
* * 大了:给出提示大了
* * 小了:给出提示小了
* * 猜中了:给出提示,恭喜你,猜中了
* * D:多次猜数据,而我们不知道要猜多少次,怎么办呢?
* * while(true) {循环的内容}
*/
public class TestRandom02 {
public static void main(String[] args) {
//2.产生1-100之间的随机数
Random r = new Random();
//bound(不包含100),直接在括号内输入100
int ranNum = r.nextInt(100) + 1;
//1.输入猜的数据
while (true) {
Scanner sc = new Scanner(System.in);
System.out.println("输入一个数:");
int num = sc.nextInt();
if (num > ranNum) {
System.out.println("大了");
} else if (num < ranNum) {
System.out.println("小了");
} else {
System.out.println("恭喜你,猜中了!");
break;
}
}
}
}
数组
数组概念
数组是存储同一种数据类型多个元素的容器。
数组既可以存储基本数据类型,也可以存储引用数据类型。
数组的定义格式
格式1:数据类型[] 数组名;
格式2:数据类型 数组名[];
注意:这两种定义做完了,数组中是没有元素值的。
数组初始化概述:
Java中的数组必须先初始化,然后才能使用。
所谓初始化:就是为数组中的数组元素分配内存空间,并为每个数组元素赋值。
数组的初始化方式
动态初始化:初始化时只指定数组长度,由系统为数组分配初始值
格式:数据类型[] 数组名 = new 数据类型[数组长度];
数组长度其实就是数组中元素的个数。
举例:
int[] arr = new int[3];
解释:定义了一个int类型的数组,这个数组中可以存放3个int类型的值。
静态初始化:初始化时指定每个数组元素的初始值,由元素个数决定数组长度
特点:
1.是定长(声明长度之后不能改变长度)
2.有索引
/**
* @author Lynn
* @create 2020-11-19-9:46
*/
public class A {
public static void main(String[] args) {
String[] names;
//表示该容器放35个元素,每个元素的默认值是null(它是字符串)
names=new String[35];
//给第一个元素赋值
names[0]="Lynn";
System.out.println(names[0]);
int[] arr=new int[100];
arr[0]=5;
//数组容器中放100个元素,整型元素默认值是0
System.out.println(arr[0]);
//动态赋值,分2步
//第一步:创建数组容器大小
//第二步:给容器中元素赋值
//静态创建数组,只需要一步,直接创建数组容器后赋值
String[] names2={"Lynn","cheery","linda"};
System.out.println(names2[2]);
//把0--10000的数放入数组
int [] arr3=new int[10000];
for (int i = 0; i < 10000; i++) {
arr3[i]=i;
System.out.println(i);
}
}
}
/**
* @author Lynn
* @create 2020-11-19-10:21
*/
public class B {
public static void main(String[] args) {
int[] arr={11,22,33,44,55,66,77,88};
//数组有下标(索引),从0开始,如果一个数组有8个元素,那么他的下标最大是7
System.out.println(arr[0]);
System.out.println(arr[7]);
System.out.println("------------------------");
//length属性可以获取数组元素的个数
System.out.println(arr.length);//下标的最大值是length-1
//遍历数组中所有元素
for (int i = 0; i < arr.length; i++) {
System.out.print(arr[i]+"\t");
}
System.out.println("------------------------");
//使用foreach遍历数组
//遍历数组,把每次遍历到的值给a
for (int a:arr){
System.out.print(a+"\t");
}
//for 和foreach的区别:for在遍历过程中可以随时知道数组的下标,而foreach不行
//数组访问过程中出现的问题
//System.out.println(arr[8]);
//ArrayIndexOutOfBoundsException 数组越界
//访问的范围超过了数组定义的范围
int[] arr2;//声明一个数组,还没有规定数组大小
//直接访问这个数组,会产生java.lang.NullPointerException,空指针异常
//数组已经不指向堆内存的数据了,你还使用数组名去访问元素
}
}
/**
* @author Lynn
* @create 2020-11-19-14:04
*/
public class F_search {
public static void main(String[] args) {
int[] arr={99,33,55,77,88,66};
//查找数组中是否存在55这个数
//普通方法 遍历 查找
//设置一个布尔类型标志
boolean flag=false;
for (int i = 0; i <arr.length ; i++) {
if(arr[i]==22){
System.out.println("22在数组中的索引是:"+arr[i]);
//设置flag为true,表示已经找到
flag=true;
}
}
//判断flag
if(!flag){
System.out.println("没有这个数!");
}
}
}
import java.security.Key;
import java.util.Arrays;
/**
* @author Lynn
* @create 2020-11-19-14:10
*/
public class F_search1 {
public static void main(String[] args) {
int[] arr={99,33,55,77,88,66};
//1.排序
Arrays.sort(arr);
//
//2.使用二分查找数据
//第一个参数:数组;第二个参数:要找的值
//返回这个值在数组中的索引
int index=Arrays.binarySearch(arr,88);
System.out.println("index:"+index);
}
}
import java.util.Arrays;
/**
* @author Lynn
* @create 2020-11-19-13:43
*/
public class F_sort {
public static void main(String[] args) {
int[] arr={99,33,55,77,88,66};
System.out.println("排序前:");
for(int i:arr){
System.out.print(i+"\t");
}
System.out.println();
//对数组进行排序,使用快速排序算法
Arrays.sort(arr);
System.out.println("排序后:");
for (int i:arr){
System.out.print(i+"\t");
}
System.out.println();
//获取最值
System.out.println("最小值:"+arr[0]);
System.out.println("最大值:"+arr[arr.length-1]);
}
}
import java.util.Arrays;
/**
* @author Lynn
* @create 2020-11-19-13:52
*/
public class F_sort1 {
public static void main(String[] args) {
//实现数组从大到小排序
int[] arr={99,33,55,77,88,66};
//1.对数组进行正序排列
Arrays.sort(arr);
//2.进行反转
int[] other=new int[arr.length];
//2.1遍历arr数组 33 55 66 77 88 99
for(int i=0;i<arr.length;i++){
//i=0
other[i]=arr[arr.length-1-i];
}
//打印
for(int i:other){
System.out.print(i+"\t");
}
System.out.println("------------------");
int[] other2=new int[arr.length];
//2.2遍历arr数组,33,55,66,77,88,99 从最后一个开始遍历
for(int i= arr.length-1;i>=0;i--){
//arr.length-1-i
other2[arr.length-1-i]=arr[i];
}
//打印
for (int i :other2) {
System.out.print(i+"\t");
}
}
}