java学习第05天(数组常见操作、数组中的数组)
(4)数组常见操作
a.遍历取值
class ArrayDemo3
{
public static void main(String[] args)
{
//System.out.println("Hello World!");
//格式1
/*
需要一个容器,但不明确容器的具体数据。
*/
//int[] arr = new int[8];
//格式2
/*
需要一个容器,储存一直的具体数据。
*/
//元素类型[] 数组名 = new 元素类型[](元素,元素,....); //int[] arr = new int[]{12,25,58,69}; int[] arr = {12,25,58,69};//写法相对较简单 /*
对数组的操作最基本的功能就是存和取。
核心思想:就是对角标的操作。
*/ //System.out.println(arr[0]); //System.out.println(arr[1]); //System.out.println(arr[2]); //System.out.println(arr[3]); //System.out.println(arr.length);//arr数组的长度 for(int x=0;x<arr.length ;x++)
{
System.out.println("arr["+x+"]="+arr[x]+";");
}
}
}
b.获取最值(最大值,最小值)
class ArrayDemo4
{
public static void main(String[] args)
{
int[] arr = {25,56,35,97,39};
int max = getMax(arr);
System.out.println("max="+max);
} /*
获取数组中的最大值
1.需要进行比较,并定义变量记录每次比较后较大的值。
2.对数组中的元素进行遍历取出,和变量中记录的元素进行比较。
如果遍历到的元素大于变量中记录的元素,就用变量记录住较大的值。
3.遍历结束,该变量记录就是最大值。 定义一个功能来实现。
明确一,结果
是数组中的元素。
明确二,位置内容
数组。
*/ public static int getMax(int[] arr)
{
//定义变量记录较大的值。
int maxElement = arr[0];
for(int x = 0;x<arr.length ;x++)
{
if(arr[x]>maxElement)
{
maxElement = arr[x];
}
}
return maxElement;
} public static int getMax_2(int[] arr)
{
//定义变量记录较大的值。
int maxIndex = 0;
for(int x = 0;x<arr.length ;x++)
{
if(arr[x]>arr[maxIndex])
{
maxIndex = x;
}
}
return arr[maxIndex];
}
}
c.排序(选择排序、冒泡排序)
class ArrayDemo4
{
public static void main(String[] args)
{
int[] arr = {25,56,35,97,39};
selectSort(arr);
} /*
选择排序
*/
public static void selectSort(int[] arr)
{
for(int x=0;x<arr.length-1;x++)
{
for(int y=x+1;y<arr.length;y++)
{
if(arr[x]>arr[y])
{
int temp = arr[x];
arr[x] = arr[y];
arr[y] = temp;
}
}
}
} /*
冒泡排序
*/
public static void bubbleSort(int[] arr)
{
for(int x=0;x<arr.length;x++)
{
for(int y=0;y<arr.length-1-x;y++)
{
if(arr[y]>arr[y+1])
{
int temp = arr[y];
arr[y] = arr[y+1];
arr[y+1] = temp;
}
}
}
}
}
d.拆半查找(二分查找)
(5)数组中的数组
class ArrayDemo5
{
public static void main(String[] args)
{
//int [] arr = {5,8,12,54,23,69,52};
//int index = getIndex(arr,619);
//int [] arr = {5,8,12,23,39,69,95};
//int index = halfSearch_2(arr,70);
//System.out.println(index);
//int index1 = Arrays.binarySearch(arr,12);//如果存在,返回的是具体角标位,如果不存在,返回的是 -插入点-1;
//System.out.println("index1="+index1);
toHex_1(60);
//System.out.println("index1="+index1);
}
/*
二分查找法
*/
public static int halfSearch(int[] arr,int key)
{
int max,min,mid;
min = 0;
max = arr.length-1;
mid = (min+max)/2;
while(arr[mid] != key)
{
if(key>arr[mid])
{
min = mid+1;
}else
{
max = mid-1;
}
if(max<min)
{
return -1;
}
mid = (min+max)/2;
}
return mid;
} public static int halfSearch_2(int[] arr, int key)
{
int max,min,mid;
min = 0;
max = arr.length-1;
while(min<max)
{
mid = (min+max)>>1;//右移1位就是除2.
if(key>arr[mid])
min = mid+1;
else if(key<arr[mid])
max = mid-1;
else
return mid;
}
return -1;
} /*
数组常见功能:查找。如果数组中有两个目的元素,返回的是第一个元素所在的索引。
*/
/*public static int getIndex(int arr[],int key)
{
for(int x=0;x<arr.length;x++)
{
if(arr[x] == key)
{
return x;
}
}
return -1;
}*/
/*
什么时候使用数组呢?
如果数据出现了对应关系,而且对应关系的一方是有序的数字编号,并作为角标使用,
这时候就必须要想到数组的使用。
就可以将这些数据储存到数组中。
根据运算的结果作为角标直接去查数组中对应的元素即可。
这种方式:称为查表法。
*/ public static void toHex_1(int num){
//定义一个对应关系表
char[] chs = {'1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};
for(int x=0;x<8;x++)
{
int temp = num & 15;
System.out.print(chs[temp]);
num = num >>>4;
}
} public static void toHex_2(int num){
//定义一个对应关系表
char[] chs = {'1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};
/*
一会查表会查到比较多的数据
数据一多,就先存起来,再进行操作。
所以定义一个数组,临时容器
*/
char[] arr = new char[8];
int pos = 0;
while(num != 0)
{
int tamp = num&15;
arr[pos++] = chs[temp];
num = num >>>4;
}
}
}
java学习第05天(数组常见操作、数组中的数组)的更多相关文章
- Java 语言基础之数组常见操作
对数组操作最基本的动作: 存和取 核心思想: 就是对角标的操作 数组常见操作: 1, 遍历 2, 获取最大值和最小值 3, 排序 4, 查找 5, 折半查找 // 1. 遍历 int[] arr = ...
- X-Cart 学习笔记(四)常见操作
目录 X-Cart 学习笔记(一)了解和安装X-Cart X-Cart 学习笔记(二)X-Cart框架1 X-Cart 学习笔记(三)X-Cart框架2 X-Cart 学习笔记(四)常见操作 五.常见 ...
- JavaScript数组常见操作
JavaScript数组常见操作 Tip: 右键在新标签中打开查看清晰大图 下面介绍JavaScript中的数组对象遍历.读写.排序等操作以及与数组相关的字符串处理操作 创建数组 一般使用数组字面量[ ...
- JS 数组常见操作汇总,数组去重、降维、排序、多数组合并实现思路整理
壹 ❀ 引 JavaScript开发中数组加工极为常见,其次在面试中被问及的概率也特别高,一直想整理一篇关于数组常见操作的文章,本文也算了却心愿了. 说在前面,文中的实现并非最佳,实现虽然有很多种,但 ...
- Java学习之路(五):常见的对象操作
Object对象 我们先来介绍一下API API(Application Programming Interface):应用程序编程接口 Java API 就是Java提供给我们使用的类,这些类将底层 ...
- java学习(四)--- String 、StringBuffer、StringBuilder 和 数组
对于 String.StringBuffer.StringBuilder比较一下 主要说说三者的不同 String 长度大小不可变 StringBuffer 和 StringBuilder 长度可变 ...
- 【代码学习】MYSQL数据库的常见操作
---恢复内容开始--- ============================== MYSQL数据库的常见操作 ============================== 一.mysql的连接与 ...
- Java初学者笔记三:关于字符串和自实现数组常见操作以及异常处理
一.字符串常见的操作 1.结合我在python中对于字符串常见处理总结出下面三个应该能算是字符串造作的TOP 3 //字符串查找子串,存在返回index,不存在返回-1 等于python的find: ...
- java 数组常见操作
1.遍历 依次访问数组中的每个元素 public class ArrayDemo04 { public static void main(String[] args) { int[] arr = { ...
随机推荐
- EOS开发基础之三:使用cleos命令行客户端操作EOS——关于钱包wallet和账户account
好了,上一节我们已经讲了关于wallet的一些基础操作,基本了解了怎么去创建一个钱包,怎么去查看钱包.上锁和解锁钱包等,这一节咱们就来开始操作账户account吧. 上一节讲到了每一个account都 ...
- 实战重现隐藏在A标签_blank下的危险漏洞,简略说明noopener的作用
前几日,在看阮一峰老师的博客文章中,发现了这么一篇 .标题为 <target = "_blank" 的危险性(英文)>.这篇文章同事看过之后因为不理解其中的危险之处,念 ...
- Alpha版总结会议——班级派
一.开会的过程 在周一下午上课的最后20分钟内,我们组进行了“班级派”的alpha版的总结会议.首先进行的是分析目前的版本情况,每个人说了自己的进度,包括已经完成的以及即将要完成的.随后是分析前段时间 ...
- RYU 灭龙战 first day
RYU 灭龙战 first day 前言 由于RYU翻译过来是龙的意思,此次主题就叫灭龙战吧 灵感来源 恶龙的三位真火-问题所在 参照了官方文档的基本操作 笔者以此执行 一个终端里 sudo mn - ...
- 第四,五周——Java编写的电梯模拟系统(结对作业)
作业代码:https://coding.net/u/liyi175/p/Dianti/git 伙伴成员:石开洪 http://www.cnblogs.com/shikaihong/(博客) 这次的作业 ...
- tp5+layui 实现上传大文件
前言: 之前所写的文件上传类通常进行考虑的是文件的类型.大小是否符合要求条件.当上传大文件时就要考虑到php的配置和服务器的配置问题.之前简单的觉得只要将php.ini中的表单上传的 大小,单脚本执行 ...
- [转帖]Git数据存储的原理浅析
Git数据存储的原理浅析 https://segmentfault.com/a/1190000016320008 写作背景 进来在闲暇的时间里在看一些关系P2P网络的拓扑发现的内容,重点关注了Ma ...
- Android控件第1类——TextView
Android提供TextView,它不能被编辑,它的子类EditText可以编辑.TextView有很多子类. 1.EditText,继承自TextView EditText可以编辑. 可以设置in ...
- 6 vue-cli mock数据
https://www.cnblogs.com/dengxiaolei/p/7338773.html //--------------------------------------const por ...
- send和sendmsg性能测试
1,摘要:测试send和sendmsg的性能,影响这两个函数性能主要有发送的字节大小,增加循环次数,从100到10000000(千万)2,基本信息cat /proc/cpuinfo查看CPU信息,如下 ...