JAVA 华为云 数组练习篇

简介: JAVA 华为云 数组练习篇

1.输入数量不定的整数(不大于10个,0结束输入)初始化数组,然后输出其长度。

【习题描述】

定义一个int型数组,输入数量不定的整数(不大于10个,整数0代表结束输入)初始化数组,判断数组的长度,然后打印输出长度的值

import java.util.Scanner;
public class Example2_5_4 {
  public static void main(String args[ ]) {
        int[] a= new int[10];
        System.out.print("输入10个以内整数型数据(0结束):");
        Scanner scanner = new Scanner(System.in);
        int b = scanner.nextInt();
        for(int i = 0;i<10&&(b!=0);i++){
            a[i]=b;
            b = scanner.nextInt();
        }
    /*
    TODO:判断数组的长度
        提示:int型数组初始化时,默认值为0
        判断a[i]是0,输出长度i,如果直到i=9没有元素为0,直接输出a.length
        打印语句:System.out.println("数组的长度是:"+i);
    */
        for(int i=0;;i++){
            if(a[i]==0){
                System.out.println("数组的长度是:"+i);
                break;
            }else if(i==9){
                System.out.println(a.length);
                break;
            }
        }
    }
}

2.对输入的5个数升序排序后输出

【习题描述】

定义一个int型数组a,输入五个整数赋值给数组,通过调用类库的sort方法对数组进行排序,最后打印输出数组中的内容。

import java.util.Arrays;
import java.util.Scanner;
public class Example4_11 {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        System.out.println("输入5个数:");
        int[] a={0,0,0,0,0};
        for(int i=0;i<5;i++){
            a[i]=sc.nextInt();
        }
        /*
      TODO:引入类库Arrays,调用其sort方法排序
        通过循环将数组中的值依次输出。
        提示:输出的每个数组元素之间用两个空格隔开
      参数说明:a[i]数组
      */
        Arrays.sort(a);
        for(int i=0;i<a.length;i++){
            System.out.print(a[i]);
            System.out.print(' ');
            System.out.print(' '); 
        //输出(a[i]+' ')输出的则不是对应的a[i]会报错 
        }
    }
}

3.数组元素逆置

【习题描述】

编写程序,定义一个有10个元素的整型数组。然后将其前5个元素与后5个元素对换,即:第1个元素与第10个元素对换,第2个元素与第9个元素对换……,输出逆置后数组元数的值

import java.io.*;
import java.util.*;
public class Main {
    public static void main(String args[]) {
        //TODO:定义一个大小为10的整型数组,并通过键盘输入10个整数(用空格分隔)
        Scanner sc = new Scanner(System.in);
        int[] a=new int[10];
        for(int i=0;i<10;i++){
            a[i]=sc.nextInt();
        }
        //TODO:将该数组按题目要求逆置
        for(int i=0;i<a.length/2;i++){
            int temp=a[i];
            a[i]=a[a.length-1-i];
            a[a.length-1-i]=temp;
        }
        //TODO:输出该数组各元素的值,要求在同一行输出,各元素间用空格分隔,参见用例描述
        for(int i=0;i<10;i++){
            System.out.print(a[i]);
            System.out.print(' ');
        }
    }
}

求解Josephus问题


【习题描述】


Josephus问题: n 个人围坐一圈,约定从编号为s (1 <= s <= n)的人 开始报数,数到 m 的那个人出列。之后又从它的下一位开始报数,数到 m 的那个人又出列,依此类推,直到所有人出列为止。要求编写程序,输入人数、报数的n起始位置s和数目m,求出列顺序。例如:7个人,从编号3的人开始,数到5的出列,则其出列顺序为7、5、4、6、2、3、1


【例子】


用例1


输入:7 3 5


输出:7 5 4 6 2 3 1


用例2


输入:5 1 7


输出:2 5 1 3 4

import java.io.*;
import java.util.*;
public class Main {
    public static void main(String[] args) {
        Scanner cin = new Scanner(System.in);
        int n = 0, s = 0, m = 0;
        //输入人数n,报数起始位置s,报数数目m
        //注意hasNext的结束需要eof,按回车后ctrl+d出现^D即已经结束即可
        while (cin.hasNext()) {
            n = cin.nextInt();
            s = cin.nextInt();
            m = cin.nextInt();
        }
        //定义一个数组存储这n个人,给每人设置编号,编号从1开始
        int[] josephus = new int[n];
        for (int i = 0; i < n; i++) {
            josephus[i] = i + 1;
        }
        //s为数组起始下标
        //TODO:求解该Josephus问题,输出出列序列(空格分隔)
        if(s>=1&&s<=n){
            s=s-1;
            while(josephus.length!=0){
                //更新数字
                n=josephus.length;
                s=(s+m-1)%n;
                //找到目标元素并打印
                System.out.print(josephus[s]);
                System.out.print(' ');
                //目标出列
                josephus[s]=0;
                //数组数字前进
                for(int i=s;i<josephus.length-1;i++){
                    int temp=josephus[i];
                    josephus[i]=josephus[i+1];
                    josephus[i+1]=temp;
                }
                //把josephus数组赋值给arr并缩短数组
                int[] arr=new int[josephus.length-1];
                for(int i=0;i<arr.length;i++){
                    arr[i]=josephus[i];
                }
                josephus=arr;
            }
        }
    }
}
目录
相关文章
|
3月前
|
存储 缓存 算法
Java 数组
【10月更文挑战第19天】Java 数组是一种非常实用的数据结构,它为我们提供了一种简单而有效的方式来存储和管理数据。通过合理地使用数组,我们能够提高程序的运行效率和代码的可读性。更加深入地了解和掌握 Java 数组的特性和应用,为我们的编程之旅增添更多的精彩。
39 4
|
3月前
|
存储 缓存 算法
提高 Java 数组性能的方法
【10月更文挑战第19天】深入探讨了提高 Java 数组性能的多种方法。通过合理运用这些策略,我们可以在处理数组时获得更好的性能表现,提升程序的运行效率。
47 2
|
3月前
|
存储 Java
Java“(array) <X> Not Initialized” (数组未初始化)错误解决
在Java中,遇到“(array) &lt;X&gt; Not Initialized”(数组未初始化)错误时,表示数组变量已被声明但尚未初始化。解决方法是在使用数组之前,通过指定数组的大小和类型来初始化数组,例如:`int[] arr = new int[5];` 或 `String[] strArr = new String[10];`。
106 2
|
3月前
|
存储 Java
什么是带有示例的 Java 中的交错数组?
什么是带有示例的 Java 中的交错数组?
61 9
|
3月前
|
Java
Java数组动态扩容和动态缩减
Java数组动态扩容和动态缩减
30 3
|
3月前
|
存储 算法 Java
Java一分钟之-数组的创建与遍历
数组作为Java中存储和操作一组相同类型数据的基本结构,其创建和遍历是编程基础中的基础。通过不同的创建方式,可以根据实际需求灵活地初始化数组。而选择合适的遍历方法,则可以提高代码的可读性和效率。掌握这些基本技能,对于深入学习Java乃至其他编程语言的数据结构和算法都是至关重要的。
34 6
|
3月前
|
存储 Java 程序员
【一步一步了解Java系列】:何为数组,何为引用类型
【一步一步了解Java系列】:何为数组,何为引用类型
38 1
|
3月前
|
存储 XML Java
如何在 Java 中将常见文档转换为 PNG 图像数组
如何在 Java 中将常见文档转换为 PNG 图像数组
23 1
|
3月前
|
存储 算法 Java
带你学习java的数组军队列
带你学习java的数组军队列
42 0
|
3月前
|
存储 机器学习/深度学习 Java
【Java】数组详解
【Java】数组详解
33 0