一、选择题

1. 下列关于数组的说法正确的是:(A)

  A. 在Java中数组的长度是可变的

  B. 数组中存储的数据的类型是相同的

  C. 数组在进行扩容操作的时候源数组的地址不发生改变

  D. int[] arr = new int[3]; arr = new int[10];是将数组的大小扩容到了10且数组中的元素依然保留了下来

  E. 数组是存储到栈内存中的。

2. 下列各项中关于数组的定义正确的是:(ACD)

  A. int[][] arr = new int[2][];  

  B. int[2][] arr = new int[][3];

  C. int[] arr[] = new int[2][2];  

  D. int arr[][] = new int[3][];

  E. int[3][3] arr = new int[][];

3. 已知数组int[ ] x,y[ ]都已经初始化,则下列各项能够正确赋值的是:(ADE)

  A. y = x;  B. y[0] = x;  C. y = x[0];  D. y[0] = x[0];  E. y[0][0] = x[0];

4. 下列数组的声明有哪些是对的?错的应该怎么修改?(AB)

  A. int[] a;

  B. int a[] = new int[3];

  C. int[] a;

      a = {1,2,3,4,5};

  改:int[] a;

    a[0] = 1;

  D. int[] a = new int[3]{1,2,3};  

  改: int[] a = new int[]{1,2,3};

二、编程题

1、定义一个数组arr,读入一个整数n,如果n在数组中存在,则输出n的下标;如果不存在,则输出-1。

import java.util.*;
/*
* 定义一个数组arr
* 读入一个整数n
* 如果n在数组中存在,则输出n的下标
* 如果不存在,则输出-1
*/
public class Array01 {
public static void main(String[] args) {
System.out.print("请输入一个整数:");
int arr[] = {1,2,3,4,5,6,7,8,9,0};
Scanner s = new Scanner(System.in);
int n = s.nextInt();
int i = 0; while(i<arr.length){
if(arr[i] == n){
System.out.println("下标:" + i);
break;
} i++;
}
if(arr[9] != n)
System.out.println("-1");
}
}

2、已知一个二维数组A表示一个矩阵,求AT。

其中AT表示二维数组A的转置,例如下面的例子:

3*2的二维数组:

public class Arr01 {
public static void main(String[] args) {
// TODO Auto-generated method stub
int[][] a={{1,2,3},{4,5,6}};
int[][] b=new int[a[0].length][a.length]; for(int i=0;i<a.length;i++){
for(int j=0;j<a[0].length;j++){
b[j][i]=a[i][j];
}
}
//输转换矩阵数组
for(int i=0;i<b.length;i++){
for(int j=0;j<b[0].length;j++){
System.out.print(b[i][j]+" ");
}
System.out.println();
}
}
}

3*3的二维数组:

public class Arr {
public static void main(String[] args) throws Exception {
int data[][] = new int[][] { { 1, 2, 3 }, { 4, 5, 6 }, { 7, 8, 9 } };
System.out.println("原来的数组:");
print(data); //调用打印方法
System.out.println("置换后数组:");
DaoZhi(data);//调用倒置排序方法
} // 二维数组列行倒置排序法
public static void DaoZhi(int arr[][]) {
// TODO Auto-generated method stub
for(int i=0; i<arr.length; i++) {
for(int j=i; j<arr[i].length; j++) {
if(i != j) {
int temp = arr[i][j];
arr[i][j] = arr[j][i];
arr[j][i] = temp;
}
}
}
print(arr);//调用打印方法
}
// 打印方法
public static void print(int arr[][]) {
for(int i=0; i<arr.length; i++) {
for(int j=0; j<arr[i].length; j++) {
System.out.print(arr[i][j] + " ");
}
System.out.println("");
}
}
}

3、给定一个数组,将这个数组中的所有元素颠倒

一维数组:

public class Arr01 {
public static void main(String[] args) {
int A[] = {1, 2, 3, 4, 5};
int Len = A.length-1;
for(int i=0, j=Len; i<j; i++, j--){
int iTemp = A[i];
A[i] = A[j];
A[j] = iTemp;
}
//foreach循环遍历数组
for(int a:A)
System.out.print(a);
}
}

二维数组:

public class AFanzhuan {
public static void main(String[] args) {
int a[][] = {{1,2,3},{4,5,6}};
int[][] b = new int[2][3]; for(int i=0; i<a.length; i++){
for(int j=0; j<a[i].length; j++){
b[i][j] = a[a.length-1-i][a[i].length-j-1];
System.out.print(b[i][j] + " ");
}
System.out.println();
}
}
}

4、杨辉三角

1    
1    1    
1    2    1    
1    3    3    1    
1    4    6    4    1    
1    5    10    10    5    1    
1    6    15    20    15    6    1    
…………

杨辉三角的特点:
1) 第i行有i个元素
2) 每一行的每一个元素和最后一个元素都是1
3) 除了1之外,每个元素的值都等于上一行同位置的元素以及前一个元素的和。
要求:输入一个数,输出对应的行数

import java.util.*;

public class YangHui {
public static void main(String[] args) {
System.out.print("input:");
Scanner s = new Scanner(System.in);
int n = s.nextInt();
int[][] arr = new int[n][]; for(int i=0; i<n; i++){
arr[i] = new int[i+1];
for(int j=0; j<=i; j++){
if(j == 0 || j == i){
arr[i][j] = 1;
}
else {
//每一个元素是它上一行的元素和斜对角元素之和
arr[i][j] = arr[i -1][j] + arr[i - 1][j - 1];
}
System.out.print(arr[i][j] + "\t");
}
System.out.println();
}
}
}

5. 15个猴子围成一圈选大王

依次1-7循环报数,报到7的猴子被淘汰,直到最后一只猴子成为大王。问:哪只猴子会成为大王?

public class Monkey {
public static void main(String[] args) {
int[] a = new int[15];
int n = 0;
int c = 0; for(int i=0; i<a.length; i++){
a[i] = i;
} while(true){
for(int i=1; i<=7; i++){
//如果a[n]==99就跳过这个元素
//比如遍历到a[6]==99,那就i--,相当于没有对他进行遍历
if(a[n]==99){
i--;
n++;
if(n==15){
n = 0;
}
continue;
}
//如果i==7,给它标记位99
if(i==7){
a[n] = 99;
}
//
n++;
if(n==15){
n = 0;
}
//遍历数组,寻找里面有多少个99,如果有14个99,就跳出循环
int b = 0;
for(int j=0; j<15; j++){
if(a[j]==99)
b++;
if(b==14)
c = 1;
}
if(c==1)
break;
}
if(c==1)
break;
}
for(int arr:a)
System.out.print(arr+" ");
}
}

6. 螺旋填数。

读入两个整数m,n,输出一个m行n列的矩阵,这个矩阵是1~m*n这些自然数按照右、下、左、上螺旋填入的结果。
例如读入数字4,5,则输出结果为:
1     2    3    4   5
14  15  16  17  6
13  20  19  18  7
12  11  10   9   8

package Day8_06;
/*读入两个整数m,n,输出一个m行n列的矩阵,这个矩阵是1~m*n这些自然数按照右、下、左、上螺旋填入的结果。
* 例如读入数字4,5,则输出结果为:
* 1   2    3   4 5
* 14  15  16  17  6
* 13  20  19  18  7
* 12  11  10   9   8
*/
import java.util.Scanner; public class LuoXuan {
public static void main(String[] args) {
System.out.println("Input:");
Scanner s = new Scanner(System.in);
int m = s.nextInt();
int n = s.nextInt(); int[][] arr = new int[m][n];
int x; //横坐标
int y; //竖坐标
int z = ; //给数组元素赋的值
int c = ; while(true){
if(z > m * n)
break;
// 打印第(c)行
for(x=c,y=c; y<n-c; y++){
arr[x][y] = z;
z++;
}
// 打印第(n-c)列
for(x=c+,y=n--c; x<m-c; x++){
arr[x][y] = z;
z++;
}
// 打印第(m-1-c)行
for(x=m--c,y=n--c; y>=c; y--){
arr[x][y] = z;
z++;
}
// 打印第(c)列
for(x=m--c,y=c; x>c; x--){
arr[x][y] = z;
z++;
}
c++;
}
for(int i=; i<m; i++){
for(int j=; j<n; j++){
System.out.print(arr[i][j] + "\t");
}
System.out.println();
}
}
}

Java经典练习题_Day04的更多相关文章

  1. Java 经典练习题_Day010

    final 变量能被显式地初始化并且只能初始化一次.被声明为 final 的对象的引用不能指向不同的对象.但是 final 对象里的数据可以被改变.也就是说 final 对象的引用不能改变,但是里面的 ...

  2. Java经典练习题_Day05

    一. 选择题 1.下列各项中的各项定义正确的是:(ACD) A.  public static void m(){}   B.  public void static m(){} C.  public ...

  3. Java经典练习题_Day03

    一.选择 B    D(死循环)    E(switch)    BC 二.编程 1.读入一个整数,表示一个人的年龄. 如果小于6岁,则输出“儿童”, 6岁到13岁,输出“少儿”;  14岁到18岁, ...

  4. Java 经典练习题_Day06

    面向对象与面向过程的比较 类与对象的关系 成员变量和局部变量 构造方法 this 构造代码块 局部代码块 匿名对象 一. 选择题 1.下列各项中关于面向对象及面向过程的说法错误的是:(BDE) A.  ...

  5. 【视频+图文】Java基础经典练习题(一)输出2-100之间的素数,及素数个数

    目录 第一题:判断2-100之间有多少个素数,并输出所有素数. 1.视频讲解: 2.思路分析: 代码讲解:以i=4为例 4.为大家准备了彩蛋: 能解决题目的代码并不是一次就可以写好的 我们需要根据我们 ...

  6. 【视频+图文】Java经典基础练习题(三):输入3个整数,并将其由小到大输出

    目录 一.视频讲解 二.思路分析 总结: 三.代码+详解+结果 四.彩蛋 能解决题目的代码并不是一次就可以写好的 我们需要根据我们的思路写出后通过debug模式找到不足再进行更改 多次测试后才可得到能 ...

  7. JAVA经典算法40题及解答

    JAVA经典算法40题 [程序1]   题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第四个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少? 1.程序分 ...

  8. Java经典算法四十例编程详解+程序实例

    JAVA经典算法40例 [程序1]   题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第四个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?   1.程 ...

  9. JAVA经典算法40题

    1: JAVA经典算法40题 2: [程序1] 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第四个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少? 3 ...

随机推荐

  1. Mysqlde的权限操作,以及增加用户

    增加用户及直接授权 ' 在这条命令里边all代表所有的权限,*.*代表所有的空间名.表名 sql的通配符 _ 代表任意的一个字符 % 代表任意的字符的任意长度 修改用户的密码 update 空间名.表 ...

  2. node 封装db层

    var db = {}; var mysql = require('mysql'); var pool = mysql.createPool({ connectionLimit: , host: '1 ...

  3. zoj 2966 Build The Electric System(最小生成树)

    Build The Electric System Time Limit: 2 Seconds      Memory Limit: 65536 KB In last winter, there wa ...

  4. QUnit 学习笔记 使用说明(一)

    一.单元测试前言 什么是单元测试? 如果是新接触单元测试的童鞋,简要的解释:就是一个JS函数/功能/模块的测试. 单元测试的工具:这里介绍QUnit Qunit原本是jqury家的,不过现在已经独立了 ...

  5. mifi随身wifi选购

    一款优秀的随身wifi不光要信号好,更要电量足 ,网速快.影响这个三个问题的主要因素就是cpu.so咱们从cpu的角度来分析下mifi 机器型号(cpu型号) TP 961 52000 (MDM962 ...

  6. eclipse ndk 配置和简单开发demo

    记录下以备忘: android开发的各种资源国内镜像 http://www.androiddevtools.cn/ 前端时间尝鲜用android stuido1.5开发了个android的小项目,发现 ...

  7. pg_bulkload使用记录

    很久之前就使用过pg_bulkload来导入数据了,并做了对比试验,现在另一个项目又需要用了,这里做个记录: 1.rpm包比较老,下下来之后发现只支持到pg94,目前我用的是pg10,因此放弃. 2. ...

  8. About libcurl and cURL in PHP

    今天在学习php时遇到要调用curl 库函数对特定url字符串进行访问操作,需要自己写一个方法进行调用,之前在linux系统中也有用到cURL 命令行工具执行对相关资源的获取,在wiki上找到了如下的 ...

  9. Kafka 单节点单Kafka Broker集群

    下载与安装 从 http://www.apache.org/dist/kafka/ 下载最新版本的 kafka,这里使用的是 kafka_2.12-0.10.2.1.tgz $ tar zxvf ka ...

  10. DBSCAN聚类︱scikit-learn中一种基于密度的聚类方式

    一.DBSCAN聚类概述 基于密度的方法的特点是不依赖于距离,而是依赖于密度,从而克服基于距离的算法只能发现"球形"聚簇的缺点. DBSCAN的核心思想是从某个核心点出发,不断向密 ...