Java数组相关算法一
一、数组反转
int[] arr = {6,29,0,4,3};
int[] arr2 = new int[arr.length];
for (int i = 0; i < arr.length; i++) {
arr2[i]=arr[arr.length-1-i];
}
System.out.println(Arrays.toString(arr2));
int[] arr = {6,29,0,4,3};
int mid = arr.length/2;
for (int i = 0,j=arr.length-1; i < mid; i++,j--) {
int a = arr[i];
arr[i] = arr[j];
arr[j] = a;
}
System.out.println(Arrays.toString(arr));
二、查找数组中指定元素的索引位置
public class FindArraryValue {
public static void main(String[] args) {
int[] arr = { 6, 29, 1, 4, 3,100,80,1000,600 };
System.out.println(find1(arr, 6));//
}
public static int findValue(int[] a, int v) {
for (int i = 0; i < a.length; i++) {
if (a[i] == v) {
return i;
}
}
return -1;
}
}
public class FindArraryValue {
public static void main(String[] args) {
int[] arr = { 6, 29, 1, 4, 3,100,80,1000,600 };
Arrays.sort(arr);
System.out.println(Arrays.toString(arr));
//[1, 3, 4, 6, 29, 80, 100, 600, 1000]
System.out.println(binaryResearch(arr, 0, arr.length, 6));
//[1, 3, 4, 6, 29, 80, 100, 600, 1000]
System.out.println(Arrays.binarySearch(arr, 6));
}
public static int binaryResearch(int[] a, int fromIndex, int toIndex, int v) {
if (a == null) {
throw new RuntimeException("数组不能为空");
}
if (fromIndex < 0) {
throw new RuntimeException("开始索引不能为负数");
}
if (fromIndex > toIndex) {
throw new RuntimeException("开始索引不能小于结束索引");
}
if (fromIndex > a.length) {
throw new RuntimeException("结束索引不能大于数组的长度");
}
int low = fromIndex;
int high = toIndex - 1;
while (low <= high) {
//无符号右移一位,即除以2
int mid = (high + low) >>> 1;
if (a[mid] < v) {
low = mid + 1;
} else if (a[mid] > v) {
high = mid - 1;
} else {
return mid;
}
}
//未找到
return -1;
}
}
三、杨辉三角
1、方法一:直接创建二维数组
public class Yang {
public static void main(String[] args) {
int yang[][] = new int[10][10];
yang[0][0]=1;
yang[1][0]=1;
yang[1][1]=1;
for (int i = 2; i <10 ; i++) {
yang[i][0]=1;
yang[i][i]=1;
for (int j = 1; j < i; j++) {
yang[i][j]=yang[i-1][j-1]+yang[i-1][j];
}
}
for (int i = 0; i <10 ; i++) {
for (int j = 0; j <= i; j++) {
System.out.print(yang[i][j]+" ");
}
System.out.println();
}
}
}
2、方法二:在二层循环中创建一位数组(推荐)
public class Yang {
public static void main(String[] args) {
int yang[][] = new int[10][];
for (int i = 0; i < yang.length; i++) {
yang[i]=new int[i+1];
yang[i][0]=1;
yang[i][i]=1;
//for (int j = 1; j < yang[i].length-1; j++) {
for (int j = 1; j < i; j++) {
yang[i][j]=yang[i-1][j-1]+yang[i-1][j];
}
}
for (int i = 0; i <10 ; i++) {
for (int j = 0; j <= i; j++) {
System.out.print(yang[i][j]+" ");
}
System.out.println();
}
}
}
四、九九乘法表
public class Jiujiu {
public static void main(String[] args) {
for (int i = 1; i < 10; i++) {
for (int j = 1; j <= i; j++) {
System.out.printf("%d * %d = %d ",j,i,i*j);
}
System.out.println();
}
}
}
Java数组相关算法一的更多相关文章
- 藏在Java数组的背后,你可能忽略的知识点
目录 引言 概念 区别于C/C++数组 区别于容器 数组特性 随机访问 Java数组与内存 解惑 数组的本质 Java中的数组是对象吗? Java中数组的类型 Java中数组的继承关系 参考资料 引言 ...
- Java数组一定要初始化才能使用吗?
数组是大多数编程语言提供的一种复合结构,如果程序需要多个类型相同的变量时,就可以考虑定义一个数组.Java语言的数组变量是引用类型的变量,因此具有Java独有的特性. 在正常的Java开发中,使用Ja ...
- java数组初始化
java数组初始化 //静态初始化数组:方法一 String cats[] = new String[] { "Tom","Sam","Mimi&qu ...
- Java基础学习-Random类和Java数组
1.随机数类(Random) package com.denniscui; import java.util.Random; /* * Random:用于产生随机数 * * 使用步骤: * ...
- Java 数组声明的几种方式
Java数组定义声明的几种方法: 1. 类型名称[] 变量名=new 类型名称[length]; 2.类型名称[] 变量名={?,?,?}; 3.类型名称[] 变量名=new 类型名称[]{?,?,? ...
- (网页)java数组去重总结(转)
转自CSDN: 1.背景 根据不同的业务逻辑,经常会遇到数组中存在多个重复元素的场合,总结了下数组的排序,留个记录. 2.实现方法 总结了四种方法,接下来进行展示 1.方法一 //数组去重方法一 ...
- java 数组和集合
1.概念说明 区别:数组固定长度的,集合,数组的长度是可以变化的. List,继承Collection,可重复.有序的对象 Set,继承Collection,不可重复.无序的对象 Map,键值对,提供 ...
- 1.1使用java数组,并开始封装我们自己的数组
今天感冒了,全身酸软无力,啥样不想做,就来学习吧,此节我们从初步使用java中提供的数组,然后分析相关情况,过渡到封装我们自己的数组. 一.我们先来感受一下java提供的数组,以整型数组(int[]) ...
- 浅析Java 数组-基础详解
什么是数组:数组对于每一门编程语言来说都是重要的数据结构之一,当然不同语言对数组的实现及处理也不尽相同. Java 数组:用来存储固定大小的同类型元素. 一 声明.创建,初始化Java 数组 写在前面 ...
随机推荐
- R语言data.table包fread读取数据
R语言处理大规模数据速度不算快,通过安装其他包比如data.table可以提升读取处理速度. 案例,分别用read.csv和data.table包的fread函数读取一个1.67万行.230列的表格数 ...
- 一、C++类库与C#类库相互调用
1.C++调用C#类库 1.准备C#类库(dll文件) 1.1.创建C#类库: 右击项目类库生成即可, 出现.dll(类库)与.pdb(pdb文件包含了编译后程序指向源代码的位置信息, 用于调试的时候 ...
- UVAlive 3485 Bridge(抛物线弧长积分)
Bridge A suspension bridge suspends the roadway from huge main cables, which extend from one end of ...
- Ansible笔记(7)---常用模块之系统类模块(cron、service)
一.cron模块 1.1作用: cron 模块可以帮助我们管理远程主机中的计划任务,功能相当于 crontab 命令. 在了解cron模块的参数之前,先写出一些计划任务的示例: # 示例1,每天的1点 ...
- CF9D How many trees? (dp)
这题我想了好久 设 \(f_{i,j}\) 为 \(i\) 结点 \(<=j\) 的方案数 固定根,枚举左右子树,就有: \[f_{i,j}=\sum_{k=0}^{n-1}f_{k,j-1}* ...
- 2018-10-01-weekly
Algorithm 77. 组合 What 给定两个整数 n 和 k,返回 1 ... n 中所有可能的 k 个数的组合. How 利用递归的思想,当凑够k个数时,就回退回去,remove掉一个数,在 ...
- LocalDateTime用法(jdk1.8 )
前言 最近看别人项目源码,发现Java8新的日期时间API很方便强大,所以转载该入门介绍博客,记录一下. 使用新时间日期API的必要性 在java8以前,或许: 当你在做有关时间日期的操作时,你会想到 ...
- C++数组读入MATLAB数据
data = rand(8, 10); fid = fopen('File.data', 'w'); if fid == - 1 error('Cannot open file for writing ...
- 030:spaceless和autoescape 标签
1.spaceless 标签: spaceless 标签:移除html标签中的空白字符.包括空格.tab键.换行等.示例代码如下: {% spaceless %} <p> <a hr ...
- @ControllerAdvice全局数据预处理
在传统项目的Controller的方法中传入参数,对象中的属性相同时,会出现以下错误 Book类和Author类 这是因为两个对象中的name相同,传参时分不清西游记和六小龄童 ...