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...54int 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),直接在括号内输入100int 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个元素,整型元素默认值是0System.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个元素,那么他的下标最大是7System.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遍历数组//遍历数组,把每次遍历到的值给afor (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;}}//判断flagif(!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 99for(int i=0;i<arr.length;i++){//i=0other[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-iother2[arr.length-1-i]=arr[i];}//打印for (int i :other2) {System.out.print(i+"\t");}}}

