第八次Java作业
1、编写一个简单程序,要求数组长度为5,分别赋值10,20,30,40,50,在控制台输出该数组的值。(知识点:数组定义和创建、一维数组初始化)[必做题]?
package test;
import java.util.Random;
public class test {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
int a[]=new int[5];
for(int b=0;b<a.length;b++){
a[b]=(b+1)*10;
System.out.println(a[b]);
}
}
}

2、将一个字符数组的值(neusofteducation)拷贝到另一个字符数组中。(知识点:数组复制) [必做题]?
package test;
import java.util.Arrays;
public class test2 {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
char a[]={'s','d','a','f','g','h'};
char b[]=new char[a.length];
System.arraycopy(a,0,b,0,a.length);
for(int c=0;c<b.length;c++){
System.out.println(b[c]);
}
}
}

3、给定一个有9个整数(1,6,2,3,9,4,5,7,8)的数组,先排序,然后输出排序后的数组的值。(知识点:Arrays.sort排序、冒泡排序)
package test;
public class test1 {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
int a[]={1,6,2,3,9,4,5,7,8};
for(int b=0;b<a.length;b++){
for(int c=0;c<a.length-b-1;c++){
if(a[c]>a[c+1]){
int temp=a[c];
a[c]=a[c+1];
a[c+1]=temp;
}
}
}
for(int b:a){
System.out.println(b+"");
}
}
}

4、 输出一个double型二维数组(长度分别为5、4,值自己设定)的值。(知识点:数组定义和创建、多维数组初始化、数组遍历)
package test;
public class test3 {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
double[][]a=new double[5][4];
for(int b=0;b< a.length;b++){
for(int c=0;c<a[b].length;c++){
a[b][c] =c;
}
}
for(int b=0;b<a.length;b++){
for(int c=0;c< a[b].length;c++){
System.out.print(a[b][c]+" ");
}
System.out.println();
}
}
}

5、 在一个有8个整数(18,25,7,36,13,2,89,63)的数组中找出其中最大的数及其下标。(知识点:数组遍历、数组元素访问) [必做题]?
package test;
public class test4 {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
int a[]={18,25,7,36,13,2,89,63};
int max=a[0],min=a[0];
int minidx =0,maxidx=0;
for(int b=1;b<a.length;b++){
if(a[b]>max){
max=a[b];
maxidx=b;
}
if (a[b]<min){
min=a[b];
minidx=b;
}
}
System.out.println("最大值为"+max+"最大值下标为"+maxidx);
System.out.println("最小值为"+min+"最小值下标为"+minidx);
}
}

作业
6、将一个数组中的元素逆序存放(知识点:数组遍历、数组元素访问)
package test;
public class test{
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
int num[]={2021,4,24};
for (inta=0;a<num.length/2;a++) {
int temp;
temp=num[a];
num[a]=num[num.length-1-a];
num[num.length-1-a]=temp;
}
for (int a=0; a<num.length;a++) {
System.out.println(num[a]);
}
}
}

7. 将一个数组中的重复元素保留一个其他的清零。(知识点:数组遍历、数组元素访问)
package test;
public class test {
public static void main(String[] args) {
// TODO Auto-generated method stub
int [] a={1,2,2,3};
for (int i = 0; i < a.length; i++) {
for (int j = 0; j < a.length; j++) {
if (a[i]==a[j]&&i!=j) { a[j]=0;
}
}
} for (int i : a) { System.out.println(i);
}
}
}

8、给定一维数组{ -10,2,3,246,-100,0,5},计算出数组中的平均值、最大值、最小值。(知识点:数组遍历、数组元素访问)
package test;
public class test {
public static void main(String[] args) {
// TODO Auto-generated method stub
int[] a = {-10,2,3,246,-100,0,5};
int temp = 0;
for(int b=0; b<a.length-1; b++) {
if(a[b+1]<a[b]) {
temp=a[b];
a[b]=a[b+1];
a[b+1]=temp;
}
} System.out.println("最大值"+a[a.length-1]);
for(int b=0; b<a.length-1; b++) {
if(a[b+1]>a[b]) {
temp=a[b];
a[b]=a[b+1];
a[b+1]=temp;
}
} System.out.println("最小值"+a[a.length-1]);
int sum = 0;
for(int b=0; b<a.length; b++) {
sum=sum+a[b];
}
System.out.println("平均值"+sum/a.length);
}
}

9、使用数组存放裴波那契数列的前20项 ,并输出 1 1 2 3 5 8 13 21
package test;
public class test {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
int a[]=new int[20];
a[0]=1;
a[1]=1;
for (int b=2;b< a.length;b++) {
a[b]=a[b-1]+a[b-2];
}
for (int b=0;b< a.length;b++) {
System.out.println(a[b]);
}
}
}

10、生成一个长度为10的随机整数数组(每个数都是0-100之间),输出,排序后,再输出
package test;
import java.util.Random;
import java.util.Arrays;
public class test{
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
int a[]=new int[10];
Random r=new Random();
for (int b=0;b< a.length;b++) {
a[b]=r.nextInt(101);
}
for (int b=0;b< a.length;b++) {
System.out.print(" "+a[b]);
}
System.out.println("\n排序后");
Arrays.sort(a);
for (int b=0;b< a.length;b++) {
System.out.print(" "+a[b]);
}
}
}

浙公网安备 33010602011771号