数组
请创建一个长度为6的整数数组,并为数组中的元素赋值。遍历数组,打印所有元素,元素之间用空格隔开。比如:
数组为:{1,2,3,4,5} 打印结果:1 2 3 4 5
1、数组中的元素有索引,开始索引和结束索引分别是什么?使用循环语句,依次通过索引获取元素即可遍历数组。
2、在打印数组元素时,是以空格分隔,并且不换行,该怎样输出?
for循环遍历数组
1、定义int数组,使用静态初始化方式为元素赋值。
2、使用for循环对数组进行遍历,循环索引从0开始,到数组的长度-1结束。
3、逐个打印数组元素,打印元素不换行,在输出元素的后面拼接空格。
package test; public class test1 { public static void main(String[] args) { int arr[] = {1,2,3,4,5,6}; for (int i = 0; i < arr.length; i++) { System.out.print(arr[i] + " "); } System.out.println(""); System.out.println("^^"); } }
现有一个小数数组{12.9, 53.54, 75.0, 99.1, 3.14}。请编写代码,找出数组中的最小值并打印。
1、数组的元素是小数,需要定义小数类型数组。
2、找最值需要先定义一个参考值,然后依次拿每个值与参考值比较即可。
将数组的第一个值作为参考值,遍历数组,依次比较,记录更小值。
1、定义double类型数组并存入元素。
2、定义double类型变量min代表最小值,初始化为数组第一个值。
3、遍历数组,用每个元素依次和变量min对比。
4、如果发现有元素小于min,则把该元素赋值给min。
5、遍历结束之后min记录的就是最小值,打印结果。
package test; public class test2 { public static void main(String[] args) { double arr[] = {12.9, 53.54, 75.0, 99.1, 3.14}; double min = arr[0]; for (int i = 1; i < arr.length; i++) { if (arr[i] < min){ min = arr[i]; // 随笔: 这是赋值,arr[ran] = arr[i]才是交换,说的这些跟这题没关系,只是联想到了打乱数组元素的知识点 } } System.out.println(min); System.out.println("^^"); } }
创建一个长度为6的整数数组。请编写代码,随机生成六个0(包含)-100(不包含)之间的整数存放到数组中,然后计算出数组中所有元素的和并打印。
1、数组有6个元素,那么就要生成6次随机数。
2、要求所有元素的和,首先需要定义变量来存储求和结果,然后再获取所有元素,依次累加就可以了。
定义求和变量,遍历数组,累加元素值。
1、定义长度为6的int数组。
2、创建随机数Random类对象。
3、遍历数组,在循环中生成随机数并给数组元素赋值。
4、定义求和变量,初始化值为0。
5、遍历数组,获取每一个元素,累加。
6、遍历结束,打印结果。
package test; import java.util.Random; public class test3 { public static void main(String[] args) { int arr[] = new int[6]; Random random = new Random(); int sum = 0; for (int i = 0; i < arr.length; i++) { int ran = random.nextInt(100); arr[i] = ran; sum = sum + arr[i]; } System.out.println(sum); System.out.println("^^"); } }
现有一个整数数组,数组中的每个元素都是[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的值即为所求,打印结果。
package test; public class test4 { public static void main(String[] args) { int arr[] = {1,6,5,2,5}; int num = 0; for (int i = 0; i < arr.length; i++) { num = num * 10 + arr[i]; } System.out.println(num); System.out.println("^^"); } } //按着操作步骤一步一步做,有点心虚的感觉,怪怪的,感觉不是自己做的一样...
定义一个数组来存储10个学生的成绩,例如:{72, 89, 65, 87, 91, 82, 71, 93, 76, 68}。计算并输出学生的平均成绩。
1、要操作数组的每一个元素,需要遍历。
2、怎样求平均数?其实只要求和之后也就知道了平均数。
使用数组的遍历操作完成。
定义保存学生成绩的数组arr。
定义变量sum用来存储和。
对数组进行遍历,求和。
和除以元素个数得到平均数。
打印结果。
package test; public class test5 { public static void main(String[] args) { //这题不按操作步骤做了 //定义一个数组来存储10个学生的成绩, //例如:{72, 89, 65, 87, 91, 82, 71, 93, 76, 68}。 //计算并输出学生的平均成绩。 //求和 int sum = 0; //计算平均成绩 int avg = 0; //定义一个数组来存储10个学生的成绩 int arr[]={1,2,3,4,5,1,2,3,4,5}; //写数组题第二步一定是遍历,第一步一定是定义,反正我现在是这样理解的 for (int i = 0; i < arr.length; i++) { //求和 sum = sum + arr[i]; } //计算平均成绩 avg = sum / arr.length; //输出平均成绩 System.out.println(avg); System.out.println("^^"); } }
有一个数组,其中有十个元素从小到大依次排列 {12,14,23,45,66,68,70,77,90,91}。再通过键盘录入一个整数数字。要求:把数字放入数组序列中,生成一个新的数组,并且数组的元素依旧是从小到大排列的。执行效果如下:
请输入一个整数数字: 50 生成的新数组是:12 14 23 45 50 66 68 70 77 90 91
数组的长度是不能改变的,所以增加一个元素需要定义一个新数组。
数组元素是从小到大排列的,如何找到新元素存放的位置?
使用数组的遍历,用元素依次和数字作比较,找到正确的存放位置。
定义原数组arr,和一个比原数组长度大1的新数组brr。->把原数组的值放到新数组中
通过键盘录入的方式输入变量num的值。
定义变量index用于记录num存放的索引位置。
遍历数组,小于或等于num的元素直接存放到原来的位置,大于num的元素往后移动一个位置。
存放结束之后,中间会空出一个位置,在遍历时用index记录这个位置。把num放在这个索引处。
最终遍历新数组打印结果。
package test; import java.util.Scanner; public class test6_6_6_6 { public static void main(String[] args) { //有一个数组, //其中有十个元素从小到大依次排列 //{12,14,23,45,66,68,70,77,90,91}。 //再通过键盘录入一个整数数字。 //要求:把数字放入数组序列中,生成一个新的数组, //并且数组的元素依旧是从小到大排列的。执行效果如下: //请输入一个整数数字: //50 //生成的新数组是:12 14 23 45 50 66 68 70 77 90 91 //键盘录入 Scanner scanner = new Scanner(System.in); int sc = scanner.nextInt(); //定义数组 int arr[] = {1,2,4,5,6,};//1 2 3 4 5 6 //定义新数组 int brr[] = new int[6]; //定义index记录sc的索引 int index = 0; //遍历数组 for (int i = 0; i < arr.length; i++) { if (arr[i] <= sc) { brr[i] = arr[i]; index = i + 1; //->服了,就一直卡在这里,一直以为是放在else里面,太困了,搞得脑子都蒙了 } else { brr[i+1] = arr[i]; } } for (int i = 0; i < brr.length; i++) { brr[index] = sc; System.out.println(brr[i]); } System.out.println("^^"); } }
定义一个数组其中包含多个数字。用自己的方式最终实现,奇数放在数组的左边,偶数放在数组的右边。(可以创建其他数组,不必须在原数组中改变)
要找奇数和偶数只需要判断对2取余即可。
找到一个奇数或偶数之后,把它放在哪个索引处?
定义一个新数组。把原数组的奇数放在新数组的左边,把原数组的偶数放在新数组的右边。
不定义新数组。找到左边的偶数,和右边的奇数互换位置。
以下以方案1为准
定义出原数组arr,其中包含多个数字。
定义新数组brr,和arr的长度一样。
定义变量left,初始值是0准备从左边放元素,定义变量right,初始值是arr.length-1准备从右边放元素。
对原数组arr进行遍历。->会不会是单独遍历,然后进行下一步(是的)
如果元素是奇数,则放在新数组brr的左边,left变量加一。->会不会不是两个遍历嵌套,是我搞错了?(是的)
如果元素是偶数,则放在新数组brr的右边,right变量减一。
遍历新数组brr打印最终结果。
package test; public class test7_7_7_7 { public static void main(String[] args) { //定义一个数组其中包含多个数字。 //用自己的方式最终实现,奇数放在数组的左边,偶数放在数组的右边。 //(可以创建其他数组,不必须在原数组中改变)->建议创建其他数组 //定义一个数组其中包含多个数字 int arr[] = {1,2,3,4,5,6};//1 3 5 6 4 2 //定义一个新数组 int brr[] = new int[6]; //奇数放在数组的左边 int left = 0; //偶数放在数组的右边 int right = arr.length-1; for (int i = 0; i < arr.length; i++) { //这三个东西是已经规定好了的,循环改变的只是里面的东西 if (arr[i] % 2 == 1) { //奇数放左边 brr[left] = arr[i]; //左边数自增 left++; } else { //偶数放右边 brr[right] = arr[i]; //右边数自减 right--; } } for (int i = 0; i < brr.length; i++) { System.out.print(brr[i] + " "); } System.out.println(""); System.out.println("^^"); } } 注:题目来源于黑马课程