当前位置: 首页 > news >正文

day05

知识点

数组

题目1

请创建一个长度为6的整数数组,并为数组中的元素赋值。遍历数组,打印所有元素,元素之间用空格隔开。比如:

数组为:{1,2,3,4,5}
打印结果:1 2 3 4 5 

训练提示

1、数组中的元素有索引,开始索引和结束索引分别是什么?使用循环语句,依次通过索引获取元素即可遍历数组。

2、在打印数组元素时,是以空格分隔,并且不换行,该怎样输出?

解题方案

for循环遍历数组

操作步骤

1、定义int数组,使用静态初始化方式为元素赋值。

2、使用for循环对数组进行遍历,循环索引从0开始,到数组的长度-1结束。

3、逐个打印数组元素,打印元素不换行,在输出元素的后面拼接空格。

参考答案

public class HomeWork {  static void main() {  //定义一个长度为6的数组  int[] arr = new int[6];  //遍历数组并赋值  for (int i = 0; i < arr.length - 1; i++) {  arr[i] = i + 1;  }  //打印所有的元素  for (int i = 0; i < arr.length - 1; i++) {  System.out.print(arr[i] + " ");  }  }  
}

题目2

现有一个小数数组{12.9, 53.54, 75.0, 99.1, 3.14}。请编写代码,找出数组中的最小值并打印。

训练提示

1、数组的元素是小数,需要定义小数类型数组。

2、找最值需要先定义一个参考值,然后依次拿每个值与参考值比较即可。

解题方案

将数组的第一个值作为参考值,遍历数组,依次比较,记录更小值。

操作步骤

1、定义double类型数组并存入元素。

2、定义double类型变量min代表最小值,初始化为数组第一个值。

3、遍历数组,用每个元素依次和变量min对比。

4、如果发现有元素小于min,则把该元素赋值给min。

5、遍历结束之后min记录的就是最小值,打印结果。

参考答案

public class HomeWork {  static void main() {  //定义一个数组  double[] arr = {12.9,53.54,75.0,99.1,3.14};  //定义一个变量用于临时储存最小值  double min = arr[0];  //遍历数组并比较大小  for (int i = 0; i < arr.length; i++) {  if (arr[i] < min) {  min = arr[i];  }  }  System.out.println("最小值为:" + min);  }  
}

题目3

创建一个长度为6的整数数组。请编写代码,随机生成六个0(包含)-100(不包含)之间的整数存放到数组中,然后计算出数组中所有元素的和并打印。

训练提示

1、数组有6个元素,那么就要生成6次随机数。

2、要求所有元素的和,首先需要定义变量来存储求和结果,然后再获取所有元素,依次累加就可以了。

解题方案

定义求和变量,遍历数组,累加元素值。

操作步骤

1、定义长度为6的int数组。

2、创建随机数Random类对象。

3、遍历数组,在循环中生成随机数并给数组元素赋值。

4、定义求和变量,初始化值为0。

5、遍历数组,获取每一个元素,累加。

6、遍历结束,打印结果。

参考答案

import java.util.Random;  public class HomeWork {  static void main() {  //定义一个长度为6的数组  int[] arr = new int[6];  //遍历数组并随机生成一个数赋值  Random rand = new Random();  for (int i = 0; i < arr.length; i++) {  arr[i] = rand.nextInt(101);  System.out.print(arr[i] + " ");  }  //定义一个变量表示和  int sum = 0;  for (int i = 0; i < arr.length; i++) {  sum +=arr[i];  }  System.out.println("数组和为:" + sum);  }  
}

题目4

现有一个整数数组,数组中的每个元素都是[0-9]之间的数字,从数组的最大索引位置开始到最小索引位置,依次表示整数的个位、十位、百位。。。依次类推。请编写程序计算,这个数组所表示的整数值。例如:

数组:{2, 1, 3, 5, 4}
表示的整数为:21354 // 注:是整数类型的两万一千三百五十四,不是字符串拼起来的。

训练提示

1、首先肯定要获取数组的每一个元素,需要遍历。

2、根据题目分析,个位元素本身就可以表示值,十位是元素乘以10来表示值,百位就是元素乘以100来表示值。。。它们之间有什么规律呢?从左至右,每一位所表示的值是下一位的十倍。根据此规律,怎样编写算法实现呢?

解题方案

遍历数组,与求和的思路相似,但算法不同,累加时需要将高位*10再累加。

操作步骤

1、定义int类型数组,使用静态初始化,将数字存入数组。

2、定义变量num用来存储最终的数值。

3、对数组进行遍历,遍历开始索引是0,结束索引是arr.length-1。

4、在循环中,把num的值乘10再加上元素的值,赋值给num变量。

5、循环上面的步骤,num的值即为所求,打印结果。

参考答案

import java.util.Random;  public class HomeWork {  static void main() {  //定义数组  int[] arr = {2,1,3,5,4};  //定义一个变量表示数组所代表的整数  int sum = 0;  //遍历数组,前一位乘上10再加1  for (int i = 0; i < arr.length; i++) {  sum = sum * 10 + arr[i];  }  System.out.println("表示整数为:" + sum);  }  
}

题目5

定义一个数组来存储10个学生的成绩,例如:{72, 89, 65, 87, 91, 82, 71, 93, 76, 68}。计算并输出学生的平均成绩。

训练提示

1、要操作数组的每一个元素,需要遍历。

2、怎样求平均数?其实只要求和之后也就知道了平均数。

解题方案

使用数组的遍历操作完成。

操作步骤

  1. 定义保存学生成绩的数组arr。
  2. 定义变量sum用来存储和。
  3. 对数组进行遍历,求和。
  4. 和除以元素个数得到平均数。
  5. 打印结果。

参考答案

import java.util.Random;  public class HomeWork {  static void main() {  //定义一个数组存储学生成绩  int[] arr = {72,89,65,87,91,82,71,93,76,68};  //定义一个变量表示和  int sum = 0;  //定义一个变量表示平均数  double avg = 0;  //遍历数组  for (int i = 0; i < arr.length; i++) {  sum += arr[i];  }  avg = (double) sum / arr.length;  System.out.println("平均数为:" + avg);  }  
}

题目6(很难)

有一个数组,其中有十个元素从小到大依次排列 {12,14,23,45,66,68,70,77,90,91}。再通过键盘录入一个整数数字。要求:把数字放入数组序列中,生成一个新的数组,并且数组的元素依旧是从小到大排列的。执行效果如下:

请输入一个整数数字:
50
生成的新数组是:12 14 23 45 50 66 68 70 77 90 91

训练提示

  1. 数组的长度是不能改变的,所以增加一个元素需要定义一个新数组。
  2. 数组元素是从小到大排列的,如何找到新元素存放的位置?

解题方案

​ 使用数组的遍历,用元素依次和数字作比较,找到正确的存放位置。

操作步骤

  1. 定义原数组arr,和一个比原数组长度大1的新数组brr。
  2. 通过键盘录入的方式输入变量num的值。
  3. 定义变量index用于记录num存放的索引位置。
  4. 遍历数组,小于或等于num的元素直接存放到原来的位置,大于num的元素往后移动一个位置。
  5. 存放结束之后,中间会空出一个位置,在遍历时用index记录这个位置。把num放在这个索引处。
  6. 最终遍历新数组打印结果。

参考答案

import java.util.Scanner;  public class HomeWork {  static void main() {  //定义一个数组  int[] arr = {12,14,23,45,66,68,70,77,90,91};  //再定义一个数组用来存储新的数组  int[] arr1 = new int[arr.length + 1];  //键盘录入一个数  Scanner sc = new Scanner(System.in);  System.out.println("请输入一个整数数字");  int number = sc.nextInt();  //遍历数组将键盘录入的数字和原数组中的数字进行比较  //若比原数组的数字大,继续比较,若比原数组的数字小,则把该数字放在该索引  //定义变量表示目标索引的位置  int index = 0;  for (int i = 0; i < arr.length; i++) {  if (number >= arr[i]) {  arr1[i] = arr[i];  //记录索引位置  index = i + 1;  }  else{  arr1[i + 1] = arr[i];  }  }  //  arr1[index] = number;  System.out.println("生成的新数组为: ");  for (int i = 0; i < arr1.length; i++) {  System.out.print(arr1[i] + " ");  }  }  
}

题目7(很难)

定义一个数组其中包含多个数字。用自己的方式最终实现,奇数放在数组的左边,偶数放在数组的右边。(可以创建其他数组,不必须在原数组中改变)

训练提示

  1. 要找奇数和偶数只需要判断对2取余即可。
  2. 找到一个奇数或偶数之后,把它放在哪个索引处?

解题方案

  1. 定义一个新数组。把原数组的奇数放在新数组的左边,把原数组的偶数放在新数组的右边。

  2. 不定义新数组。找到左边的偶数,和右边的奇数互换位置。

    以下以方案1为准

操作步骤

  1. 定义出原数组arr,其中包含多个数字。
  2. 定义新数组brr,和arr的长度一样。
  3. 定义变量left,初始值是0准备从左边放元素,定义变量right,初始值是arr.length-1准备从右边放元素。
  4. 对原数组arr进行遍历。
  5. 如果元素是奇数,则放在新数组brr的左边,left变量加一。
  6. 如果元素是偶数,则放在新数组brr的右边,right变量减一。
  7. 遍历新数组brr打印最终结果。

参考答案

public class HomeWork {  static void main() {  //定义数组  int[] arr = {1,2,3,4,5,6,7,8,9,10};  //定义新数组  int[] arr1 = new int[10];  //定义两个变量分别表示放在新数组的左边和右边  int left = 0;  int right = arr.length-1;  //遍历数组并判断奇数还是偶数,奇数放左边偶数放右边  for (int i = 0; i < arr.length; i++) {  if(arr[i] % 2 != 0){  arr1[left] = arr[i];  left++;  }else{  arr1[right] = arr[i];  right--;  }  }  System.out.println("新数组为: ");  for (int i = 0; i < arr1.length; i++) {  System.out.print(arr1[i]+" ");  }  }  
}
http://www.hskmm.com/?act=detail&tid=31868

相关文章:

  • [AI生成]Spark-TTS个人理解
  • 2025.10.3 测试
  • [20251015]建立和完善col_vlist.sql脚本.txt
  • [20251014]建立和完善col_list.sql脚本.txt
  • [20251014]建立完善通用的prx.sql脚本.txt
  • 倍增法
  • 复杂版式与印章干扰下的高精度社会团体法人登记证书识别技术
  • 征程 6 | BPU trace 简介与实操
  • 2025年预应力千斤顶厂家最新权威推荐榜:批发采购、张拉设备、同步顶升系统专业供应商综合测评与选购指南
  • 2025.10.15训练记录
  • 利用Next.js中间件漏洞实现SSRF攻击与RCE
  • 三级医疗服务体系 (Three Tiers of Care)
  • 2025年瑕疵检测设备厂家最新推荐排行榜,表面瑕疵检测,薄膜瑕疵检测,铝箔瑕疵在线检测,外观瑕疵检测机公司推荐!
  • 2025年冷却塔厂家最新推荐排行榜:高效制冷与稳定性能之选!
  • 牛客2025秋季算法编程训练联赛1
  • 2025 年风淋室厂家选哪家?广州灵洁凭技术专利与全链服务打造净化设备优质之选
  • 251015读书报告
  • MySQL
  • 元推理框架的诞生,是绝对真实的证明,彻底击溃虚无论
  • JAVA8 map flatmap用法
  • Spring bean初始化过程
  • 吴恩达深度学习课程一:神经网络和深度学习 第二周:神经网络基础 课后习题和代码实践
  • 【Windows】如何管理电脑磁盘文件,保持简洁 - 教程
  • 范围综述
  • 低代码软件开发流程
  • 生成器
  • CSP-S模拟30
  • 2025多校冲刺CSP模拟赛5
  • float
  • 读书报告和代码