练习1:
使用公式C=(5/9)(F-32)打印下列华氏温度与摄氏温度对照表。
0 -17
20 -6
40 4
60 15
80 26
100 37
120 48
140 60
160 71
180 82
200 93
220 104
240 115
260 126
280 137
300 148
思考:
加入制表符使数据输出更整齐;
让摄氏温度保留一位小数。
修改温度转换程序,要求以逆序(从300度到0度的顺序)打印温度转换表。
练习2:
打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身。例如:153 是一个"水仙花数",因为153=1的三次方+5的三次方+3的三次方。
public class ShuiXianHua {
/*
* 打印出所有的"水仙花数"
*/
public static void main(String[] args) {
System.out.print("所有的“水仙花数”: ");
for (int i = 100; i < 1000; i++) {
int ge,shi,bai;
bai=i/100;
shi=(i-bai*100)/10;
ge=i-bai*100-shi*10;
if (i==ge*ge*ge+shi*shi*shi+bai*bai*bai) {
System.out.print(i+" ");
}
}
}
}
练习3:
求1+2!+3!+...+20!的和
public class JieCheng {/*
* 求1+2!+3!+...+20!的和
*/
public static void main(String[] args) {
long x=0,y=1;
for (int i = 1; i <=20; i++) {
for (int j = 1; j <= i; j++) {
y*=j;
}
x+=y;
y=1;
}
System.out.print("1+2!+3!+...+20!的和是"+x);
}
}
练习4:
求一个n阶方阵对角线元素之和。
import java.util.Scanner;public class Duijiaoxian {
/*
* 求一个n阶方阵对角线元素之和。
*/
public static void main(String[] args) {
int sum=0;
Scanner read=new Scanner(System.in);
System.out.println("请输入方阵的阶数n:");
int n=read.nextInt();
int[][] a=new int[n][n];
for (int i = 0; i < a.length; i++)
for (int j = 0; j < a.length; j++) {
System.out.println("请输入第"+i+"行第"+j+"列元素的值");
a[i][j]=read.nextInt();
}
System.out.println("输入的"+n+"阶方阵为:");
for (int i = 0; i < a.length; i++) {
for (int j = 0; j < a.length; j++) {
System.out.print(a[i][j]+" ");
}
System.out.println();
}
for (int i = 0; i < a.length; i++) {
sum+=a[i][i];
}
System.out.println(n+"阶方阵对角线元素之和:"+sum);
}
}
练习5:
输入一个一维数组,最大的与第一个元素交换,最小的与最后一个元素交换,输出数组。
import java.util.Scanner;public class Switch {
/*
* 输入一个一维数组,最大的与第一个元素交换,最小的与最后一个元素交换,输出数组。
*/
public static void main(String[] args) {
Scanner read=new Scanner(System.in);
System.out.println("请输入元素的个数n");
int n=read.nextInt();
int a[]=new int[n];
//依次输入数组元素的值
for (int i = 0; i <a.length; i++) {
System.out.println("请输入第"+i+"元素的值");
a[i]=read.nextInt();
}
System.out.println("输入的一维数组的元素为");
//依次输出数组元素的值
for (int i = 0; i <a.length; i++) {
System.out.print(a[i]+" ");
}
System.out.println();
int max=0,min=0,c=0;
max=a[0];
min=a[0];
//找出最大数max和最小数min
for (int i = 0; i < a.length; i++) {
if (max<a[i]) {
max=a[i];
}
if (min>a[i]) {
min=a[i];
}
}
int x=0,y=0;
//找出最大数下标和最小数下标
for (int i = 0; i < a.length; i++) {
if (max==a[i]) {
x=i;
}
if (min==a[i]) {
y=i;
}
}
c=a[x];
a[x]=a[0];
a[0]=c;
c=a[y];
a[y]=a[a.length-1];
a[a.length-1]=c;
System.out.println("最大的与第一个元素交换,最小的与最后一个元素交换,输出数组:");
for (int i = 0; i < a.length; i++) {
System.out.print(a[i]+" ");
}
}
}