第八周上机加作业
1、编写一个简单程序,要求数组长度为5,分别赋值10,20,30,40,50,在控制台输出该数组的值。(知识点:数组定义和创建、一维数组初始化)[必做题]?
public static void main(String[] args) { // TODO Auto-generated method stub Scanner input=new Scanner(System.in); int a[]=new int[5]; for (int i = 0; i < a.length; i++) { a[i]=input.nextInt(); }for (int i : a) { System.out.println(i); }
2、将一个字符数组的值(neusofteducation)拷贝到另一个字符数组中。(知识点:数组复制) [必做题]?
char a[]={'n','e','u','s','o','f','t','e','d','u','c','a','t','i','o','n'}; char []a1=new char[20]; System.arraycopy(a, 13, a1, 4, 3); System.out.println(Arrays.toString(a1));
3、给定一个有9个整数(1,6,2,3,9,4,5,7,8)的数组,先排序,然后输出排序后的数组的值。(知识点:Arrays.sort排序、冒泡排序)
int[] a = { 1, 6, 2, 3, 9, 4, 5, 7, 8 }; for (int i = 0; i < a.length - 1; i++) { for (int j = 0; j < a.length - 1 - i; j++) { if (a[j] > a[j + 1]) { int b = a[j]; a[j] = a[j + 1]; a[j + 1] = b; } } } for (int i : a) { System.out.println(i); }
4、 输出一个double型二维数组(长度分别为5、4,值自己设定)的值。(知识点:数组定义和创建、多维数组初始化、数组遍历)
double[][] a = new double[5][4]; for (int i = 0; i < a.length; i++) { for (int j = 0; j < a[i].length; j++) { a[i][j] = j; } } System.out.println("矩阵是"); for (int i = 0; i < a.length; i++) { for (int j = 0; j < a[i].length; j++) { System.out.print(a[i][j] + " "); } System.out.println(); }
5、 在一个有8个整数(18,25,7,36,13,2,89,63)的数组中找出其中最大的数及其下标。(知识点:数组遍历、数组元素访问) [必做题]?
int[] a = { 18, 25, 7, 36, 13, 2, 89, 63 }; int max = a[0]; int maxidx = 0; for (int i = 1; i < a.length; i++) { if (a[i] > max) { max = a[i]; maxidx = i; } } System.out.println("最大值是" + max + "下标是" + maxidx);
作业
6、将一个数组中的元素逆序存放(知识点:数组遍历、数组元素访问)
int a[]={1,4,3,2,5}; for (int i = 0; i < a.length/2; i++) { int b=a[i]; a[i]=a[a.length-i-1]; a[a.length-i-1]=b; }for (int i = 0; i < a.length; i++) { System.out.println(+a[i]); }
7. 将一个数组中的重复元素保留一个其他的清零。(知识点:数组遍历、数组元素访问)
int a[]={1,4,3,4,5}; for (int i = 0; i < a.length; i++) { for (int j = 1; j < a.length; j++) { if(a[i]==a[j]&&i!=j){ a[j]=0; } } }for (int i = 0; i < a.length; i++) { System.out.println(a[i]); }
8、给定一维数组{ -10,2,3,246,-100,0,5},计算出数组中的平均值、最大值、最小值。(知识点:数组遍历、数组元素访问)
int a[]={-10,2,3,246,-100,0,5}; int max=a[0],min=a[0],pingjun,sum=0; for (int i = 0; i < a.length; i++) { sum+=a[i]; if(max<a[i]) max=a[i]; if(min>a[i]) min=a[i]; }pingjun=sum/a.length; System.out.println("最大值是: "+max+"最小值是: "+min+"平均值是: "+pingjun);
9、使用数组存放裴波那契数列的前20项 ,并输出 1 1 2 3 5 8 13 21
int array[]=new int[20]; array[0]=1;array[1]=1; for(int i=2;i<array.length;i++){ array[i]=array[i-1]+array[i-2]; } for(int i=0;i<20;i++){ System.out.print(" "+array[i]); }
10、生成一个长度为10的随机整数数组(每个数都是0-100之间),输出,排序后,再输出
int input=new Random().nextInt(10); int array[]=new int[10]; System.out.println("生成的数组:"); for (int i = 0; i < array.length; i++) { array[i]=new Random().nextInt(100); System.out.print(" "+array[i]); } System.out.println(); System.out.println("排序后:"); int temp=0; for (int i = 0; i < array.length-1; i++) { for (int j = 0; j < array.length-1-i; j++) { if (array[j]<array[j+1]) { temp=array[j]; array[j]=array[j+1]; array[j+1]=temp; } } } for (int i : array) { System.out.print(" "+i); }