1.有一个已经排好序的数组。现输入一个数,要求按原来的规律将它插入数组中。

分析思路:

  先通过Random类随机创建一个数组,再调用Arrays类中的排序方法sort排好序,然后再开始实现功能。

  按原来的规律插入数组,很简单,只要找到合适的插入位置n,然后将n之前的数组元素直接复制到新数组的对应位置,n处插入输入的数字,n之后的元素后移一格再移到新数组就完成了。

  最关键的就是要找到合适的插入位置。而查找算法显然二分查找为优。这里我投了个懒,直接使用Arrays类中的二分查找方法binarySearch()来查找输入的num,若数组中存在和num一样的数,则该方法的返回值即为该数的下标位置,那么插入位置n就是这个返回值;而如果数组中不存在num,则该方法能够返回一个负数,num比数组第一个元素还小则为-1,此时插入位置应该为0,大于第一个元素小于第二个元素为-2,此时插入位置应为1,以此类推。。。那么显然插入位置应该为返回值取绝对值再减一。

  找到位置实现就简单啦。具体代码如下:

 import java.util.Arrays;
import java.util.Random;
import java.util.Scanner; /**
* 有一个已经排好序的数组。现输入一个数,要求按原来的规律将它插入数组中。
*
* @author ChenZX
*
*/
public class Test03 { public static void main(String[] args) {
Random r = new Random();
int[] arr = new int[10];
for(int i=0;i<10;i++){ //随机生成数组
arr[i]= r.nextInt(100);
}
System.out.println(Arrays.toString(arr));
Arrays.sort(arr); //排序
System.out.println(Arrays.toString(arr)); Scanner s = new Scanner(System.in);
System.out.println("请输入一个数:");
int num = s.nextInt();
s.close();
int bs =Arrays.binarySearch(arr, num); //二分查找的结果存入bs
int n = 0; //插入位置
if(bs<0){ //查找失败,则插入位置为bs的绝对值-1
n = Math.abs(bs)-1;
}else{ //查找成功,则插入位置即bs
n = bs;
}
System.out.println(bs); int[] arr2 = new int[arr.length+1]; //建立一个新数组,长度为原数组长度+1
for(int i=0;i<arr2.length;i++){
if(i<n){ //在插入位置之前的部分直接复制就行
arr2[i]=arr[i];
}else if(i==n){ //将输入数字插入对应位置
arr2[i]=num;
}else{ //插入位置之后的数全部向后移动一格
arr2[i]=arr[i-1];
}
}
System.out.println("插入数后的数组为:");
System.out.println(Arrays.toString(arr2));
}
}

2.求一个3*3矩阵对角线元素之和

分析思路:

  这是一道矩阵的编程实现题。Java中矩阵一般都是通过二维数组实现的。

  具体代码如下:

 import java.util.Random;

 /**
* 求一个3*3矩阵对角线元素之和
*
* @author ChenZX
*
*/
public class Test04 { public static void main(String[] args) {
int sum = 0; //和
int[][] arr = new int[3][3];
Random r = new Random();
for(int i=0;i<3;i++){ //随机生成矩阵
for(int j=0;j<3;j++){
arr[i][j] = r.nextInt(10); //0到9
}
}
for(int i=0;i<3;i++){ //遍历矩阵
for(int j=0;j<3;j++){
System.out.print(arr[i][j]+" "); //打印矩阵元素
if(i==j){ //如果为对角线元素
sum += arr[i][j]; //求和
}
}
System.out.println(); //每输出3个元素换行
}
System.out.println("此矩阵对角线的和为:"+sum);
}
}

Java-每日编程练习题②(数组练习)的更多相关文章

  1. 6、50道JAVA基础编程练习题跟答案

    50道JAVA基础编程练习题 [程序1] 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少? 程序分析 ...

  2. 50道JAVA基础编程练习题

    50道JAVA基础编程练习题 [程序1] 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子对数为多少? 程序分析 ...

  3. 50道JAVA基础编程练习题 - 题目

    50道JAVA基础编程练习题[1]题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少? [2]题目:判断 ...

  4. Java每日编程day2

    Java每日编程day2 第一题 package com.pcx.day2; /* * 九九乘法表并逆序 */ public class JiuJiu { public static void mai ...

  5. JAVA 基础编程练习题31 【程序 31 数组逆序】

    31 [程序 31 数组逆序] 题目:将一个数组逆序输出. 程序分析:用第一个与最后一个交换. package cskaoyan; public class cskaoyan31 { @org.jun ...

  6. JAVA 基础编程练习题

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

  7. 【搬砖】安卓入门(4)- Java开发编程基础--数组

    05.01_Java语言基础(数组概述和定义格式说明)(了解) A:为什么要有数组(容器) 为了存储同种数据类型的多个值 B:数组概念 数组是存储同一种数据类型多个元素的集合.也可以看成是一个容器. ...

  8. JAVA 基础编程练习题36 【程序 36 移动位置】

    36 [程序 36 移动位置] 题目:有 n 个整数,使其前面各数顺序向后移 m 个位置,最后 m 个数变成最前面的 m 个数 package cskaoyan; public class cskao ...

  9. JAVA 基础编程练习题35 【程序 35 最大最小交换】

    35 [程序 35 最大最小交换] 题目:输入数组,最大的与第一个元素交换,最小的与最后一个元素交换,输出数组. package cskaoyan; public class cskaoyan35 { ...

  10. JAVA 基础编程练习题30 【程序 30 插入数字】

    30 [程序 30 插入数字] 题目:有一个已经排好序的数组.现输入一个数,要求按原来的规律将它插入数组中. 程序分析:首先判断此数是否大于最后一个数,然后再考虑插入中间的数的情况,插入后此元素之后的 ...

随机推荐

  1. 通过VirtualBox安装Linux系统(CentOS7)

    本文目的:创建虚拟系统.在windows系统中通过虚拟工具VirtualBox创建一个虚拟系统CentOS. 备注:(1)版本如下:VirtualBox-5.2.12-122591-Win 和Cent ...

  2. Flask开发微电影网站(二)

    1.安装数据库连接依赖包 pip install flask-sqlalchemy 2.创建movie数据库 在CentOS虚拟机,进入MaridDB数据库提示符,创建movie数据库 create ...

  3. 使用OAuth2的SSO分析

    参考:https://github.com/spring-guides/tut-spring-security-and-angular-js/blob/master/oauth2-vanilla/RE ...

  4. pycharm跨目录调用文件

    笔者今天在一个测试qq群中遇到解决跨目录中调用文件的问题.现在来详细说一下. 以下图目录为例: 1.同目录下直接调用掉用.test2.py和test3.py在同一个目录test2下. 所以在test3 ...

  5. Intellij IDEA 安装lombok及使用详解

    项目中经常使用bean,entity等类,绝大部分数据类类中都需要get.set.toString.equals和hashCode方法,虽然eclipse和idea开发环境下都有自动生成的快捷方式,但 ...

  6. Centos7 修改硬件时间和系统时间

    查看系统时间 [root@localhost ~]# date Tue Jun 13 10:20:13 CST 2017 查看硬件时间 [root@localhost ~]# hwclock --sh ...

  7. Java 读书笔记 (六) 引用类型

    Java里使用long类型的数据要在数值后面加上L,否则会作为整型解析. 引用类型 引用类型是一个对象类型,它的值是指向内存空间的引用,就是地址, 所指向的内存中保存着变量所表示的一个值或一组值. i ...

  8. Stackoverflow 最受关注的 10 个 Java 问题

    Stack Overflow 是一个大型的编程知识库.在 Stack Overflow 中已经有数以百万计的问题,并且很多答案有着很高的质量.这就是为什么 Stack Overflow 的答案经常位于 ...

  9. fasthttp 文档手册

    fasthttp 文档手册 貌似文章有最大长度限制,完整全文地址:https://github.com/DavidCai1993/my-blog/issues/35 常量 const ( Compre ...

  10. 【bzoj 3131】[Sdoi2013]淘金

    Description 小Z在玩一个叫做<淘金者>的游戏.游戏的世界是一个二维坐标.X轴.Y轴坐标范围均为1..N.初始的时候,所有的整数坐标点上均有一块金子,共N*N块.    一阵风吹 ...