练习4:
求一个n阶方阵对角线元素之和。
import java.util.Scanner;
public class diagonal {
public static void main(String[] args) {
// TODO Auto-generated method stub
int n,sum1=0,sum2=0;
System.out.println("请输入方阵的阶数:");
Scanner input=new Scanner(System.in);
n=input.nextInt();
int[][] a=new int[n][n];
System.out.println("请依次输入每个数组元素的值");
for(int i=0;i<n;i++){
for(int j=0;j<n;j++){
a[i][j]=input.nextInt();
if(i==j){
sum1+=a[i][j];
}
if(j==n-1-i){
sum2+=a[i][j];
}
}
}
System.out.println("主对角线之和为:"+sum1);
System.out.println("辅对角线之和为:"+sum2);
}
}
运行结果:
练习5:
输入一个一维数组,最大的与第一个元素交换,最小的与最后一个元素交换,输出数组。
实现代码:
import java.util.Scanner;
public class change {
public static void main(String[] args) {
// TODO Auto-generated method stub
int n;
System.out.println("请输入数组元素的个数");
Scanner input=new Scanner(System.in);
n=input.nextInt();
int[] a=new int[n];
for(int i=0;i<a.length;i++){
System.out.print("输入第"+(i+1)+"个:");
a[i]=input.nextInt();
}
int max=0,min=0;
int temp;
for(int i=0;i<n;i++){
if(a[i]>a[max]){
max=i;//取得数组中最大值的下标
}
if(a[i]<a[min]){
min=i;//取得数组中最小值的下标
}
}
temp=a[max];
a[max]=a[0];
a[0]=temp;//最大值与a[0]交换
temp=a[min];
a[min]=a[n-1];
a[n-1]=temp;//最小值与a[n-1]交换
for(int i=0;i<a.length;i++){//依次输出数组元素
System.out.println(a[i]);
}
}
}
总结:尽量使程序更加简洁易懂