java基础(4)-数组(1)
数组:存储同一种数据类型的多个元素的容器
数组初始化:
- 元素类型[] 数组名 = new 元素类型[数组长度]
int [] arr = new int[5] - 元素类型[] 数组名 = new 元素类型[] {元素,元素,...}
int [] arr = new int [] {1,2,3,4,5}
int [] arr = {1,2,3,4,5}
内存分配
栈内存:用于存储局部变量,当数据使用完时,所占空间会自动释放。一些基本类型的变量和对象的引用变量都是在函数栈内存中分配
堆内存:用于存放由new创建的对象和数组
方法区:
堆内存特点:
每个new出来的东西都有地址值
每个变量都有默认值
常见数组操作
- 获取数组中的元素
class ArrayDemo3{
public static void main(String[] args){
//int[] arr = new int[3];
int[] arr = {,,,,,};
for(int i=;i<arr.length;i++){
System.out.println("arr["+i+"]="+arr[i]+";");
}
}
}
/*
arr.lenth 表示返回数组arr的长度
*/
- 数组元素求和
class ArraySum{
public static void main(String[] args){
int[] arr = new int[]{,,,,,,,,,};
int sum = ;
for(int i=;i<arr.length;i++){
sum += arr[i];
}
System.out.println("sum="+sum);
}
}
- 遍历数组中的元素
public class ArrayDemo4{
public static void main(String[] args){
int[] arr = new int[]{,,,};
// printArray(arr);//可以直接调用,也可以ArrayDemo4.printArray(arr);
printArray1(arr);
}
public static void printArray(int[] arr){ //注意这是静态方法
for(int i = ;i<arr.length;i++){
System.out.println(arr[i]);
}
}
public static void printArray1(int[] arr){
for(int i = ;i<arr.length;i++){
if(i==arr.length-){ //如果是最后一个元素
System.out.println(arr[i]);
}else{ //如果不是最后一个元素
System.out.print(arr[i]+",");
}
}
}
}
/*
运行结果:
1,2,34,4
*/
- 求最大值和最小值
class ArrayTest1{
public static void main(String[] args){
int[] arr = new int[]{,,,};//定义一个数组
/*
int max = arr[0];
for(int i = 1; i<arr.length;i++){
if(arr[i]>max){
max = arr[i];
}
}
System.out.println(max);
*/
int max = getMax(arr);//静态方法可以直接调用
// System.out.println(max);
int min = getMin(arr);
System.out.println(min);
}
public static int getMax(int[] arr){
//找数组中任一元素作为参照物
int max = arr[];
//遍历其他元素
for(int i = ;i<arr.length;i++){
//依次获取和参照物比较,如果大就留下来,小酒离开
if(arr[i]>arr[]){
max = arr[i];
}
}
//参照物里面保存的即为最大值
return max;
}
public static int getMin(int[] arr){
int min = arr[];
for(int i = ;i<arr.length;i++){
if(arr[i]<min){
min = arr[i];
}
}
return min;
}
}
- 数组反转
class ArrayDemo{
public static void main(String[] args){
int[] arr = new int[]{,,,,};
System.out.print("原数组:");
printArray(arr);
System.out.print("反转后数组:");
reverseArray(arr);
}
//遍历数组
public static void printArray(int[] arr){
for(int i = ;i<arr.length;i++){
// System.out.println(arr[i]);//将每个元素输出,一个元素一行
if(i == arr.length-){
System.out.println(arr[i]);
}else{
System.out.print(arr[i]+",");
}
}
}
//反转数组
public static void reverseArray(int[] arr){
for(int i = ;i<arr.length/;i++){
int temp = arr[i];
arr[i] = arr[arr.length--i];
arr[arr.length--i] = temp;
}
printArray(arr);//这里调用打印数组方法,不能直接打印arr,这样是地址值
}
}
/*
原数组:112,32,45,543,76
反转后数组:76,543,45,32,112
*/
- 选择排序
class ArrayTest2{
//排序方法
public static void selectSort(int[] arr){
for(int x=;x<arr.length;x++){
for(int y=x+;y<arr.length-;y++){
if(arr[x]>arr[y]){
int temp = arr[x];
arr[x] = arr[y];
arr[y] = temp;
}
}
}
}
//主方法
public static void main(String[] args){
int[] arr = {,,,,,,};
printArray(arr);
selectSort(arr);
printArray(arr);
}
//打印数组方法
public static void printArray(int[] arr){
System.out.print("[");
for(int x=;x<arr.length;x++){
if(x!=arr.length-){
System.out.print(arr[x]+",");
}else{
System.out.println(arr[x]+"]");
}
}
}
}
java基础(4)-数组(1)的更多相关文章
- Java基础-反转数组
/** java基础,如何将一个数组反转,思考方法采用使用临时变量的情况下,将第一个元素与第二个元素进行反转,需要定义两个索引,一个记录数组的第一个元素与最后一个元素,将其两两交换* */public ...
- Java基础之 数组详解
前言:Java内功心法之数组详解,看完这篇你向Java大神的路上又迈出了一步(有什么问题或者需要资料可以联系我的扣扣:734999078) 数组概念 同一种类型数据的集合.其实数组就是一个容器. 数组 ...
- java基础(十) 数组类型
1. 数组类简介 在java中,数组也是一种引用类型,即是一种类. 我们来看一个例子,理解一下数组类: public static void main(String[] args) { Class ...
- java 基础概念 -- 数组与内存控制
问题1: Java在声明数组的过程中,是怎样分配内存的? 在栈内存中 建一个数组变量,再在堆内存中 建一个 数组对象.至于详细的内存分配细节,还得看 该初始化是 数组动态初始化 还是 数组静态初始化. ...
- Java基础:数组的声明,循环,赋值,拷贝。
数组的声明 一般有两种形式的声明: int[] a; int a[]; 这两种声明都没错,但是大多数都使用第一种声明,因为变量名是独立的,不带任何符号. 声明一个数组,并没有将a真正的初始化为一个数组 ...
- Java基础总结--数组
---数组的定义---组织存储一组数据1.存放相同类型数据的集合--就是一种容器本质上变量也是一种容器--区别就是只存储了一个数据的容器--面对容器,而不是分散的数据eg.买一盘鸡蛋--蛋托其实就是容 ...
- java 基础知识-数组的7种算法(排序、求和、最值、遍历...)
遍历 遍历就是把这个数组的每个元素 显示出来 遍历的方法就是先定义这个数组的大小,然后用FOR循环来完成数组,例如 double[] score = new double[5]; Scanner in ...
- Java基础之数组类型
对于Java,前面的一些基础概念不是很想写,看了看还是从数组开始写吧(毕竟数组是第一个引用类型,相对复杂一点),我也是学了JAVA不是很久,目前看完了JAVA的基础视频,还有JAVA疯狂讲义这本书的大 ...
- 黑马程序员——JAVA基础之数组
------- android培训.java培训.期待与您交流! ---------- 数组: 数组的定义: 数组是相同类型数据的集合, 描述的是相同类型的若干个数据按照一定的先后顺序排列组合而成,其 ...
- Java基础从数组到集合之间关键字的区别!!!!
1.&& 和 &区别和联系: 相同点 : 结果是一样的. 不同点 :如果使用双&号判断,如果说条件一为false,不会判断条件二,但是单&号会继续判 ...
随机推荐
- boost::lockfree::stack
#include <boost/thread/thread.hpp> #include <boost/lockfree/stack.hpp> #include <iost ...
- NoSQL-redis with python
首先,先去看了一下NoSQL的概念: Wiki中参考的NoSQL终极指南(nosql-database.org)中说: NoSQL DEFINITION: Next Generation Databa ...
- codeblocks在进行多线程出现phread问题
undefined reference to 'pthread_create' 出现这个错误是因为编译默认不会链接进程库. 可以选择用gcc进行编译 加上-lpthread 比如:gcc exampl ...
- Win7系统安装 MySQL 8.0.11
1. 下载 MySQL 8.0.11 版本 下载地址: https://cdn.mysql.com//Downloads/MySQL-8.0/mysql-8.0.11-winx64.zip 2. 下载 ...
- Tarjan 求桥,割,强连通
最近遇到了这种模板题,记录一下 tarjan求桥,求割 #include <bits/stdc++.h> using namespace std; #define MOD 99824435 ...
- 通过jdt解析spring mvc中url-类-方法的对应关系
依赖 <dependencies> <dependency> <groupId>org.eclipse.jdt</groupId> <artifa ...
- 设置请求timeout超时
import requests r = requests.get("http://www.cnblogs.com/yoyoketang/", timeout=1) # 设置超时 p ...
- 20170401 ABAP调用CIS webservice
问题: SAP abap SRM java 调webservice 不通, CIS java 这边的webservice 可以通, WHY? key:请求头,系统框架的问题, LF:因为请求头的 ...
- 递归函数(Day15)
一.递归的定义 在一个函数里面再调用这个函数本身 递归特性 1.必须有一个明确的结束条件 2.每次进入更深一层递归时,问题规模相比于上一次的递归有所减少 二.递归的应用 1.递归函数与三层菜单 men ...
- 【后缀数组之SA数组】【真难懂啊】
基本上一搜后缀数组网上的模板都是<后缀数组——处理字符串的有力工具>这一篇的注释,O(nlogn)的复杂度确实很强大,但对于初次接触(比如窝)的人来说理解起来也着实有些困难(比如窝就活活好 ...