练习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度的顺序)打印温度转换表。
代码:
public class Temp{
/*
public static void main(String args[]){
for(int TempF=0;TempF<=300;){
double TempC=(5.0/9.0)*(TempF-32);
System.out.printf(TempF+"\t"+"%.1f"+"\n",TempC);
TempF=TempF+20;
}
}
*/
public static void main(String args[]){
System.out.println("【按顺序输出温度转换】");
for(int TempF1=0;TempF1<=300;){
double TempC1=(5.0/9.0)*(TempF1-32);
System.out.printf(TempF1+"\t"+"%.1f"+"\n",TempC1);
TempF1=TempF1+20;
}
System.out.println("【逆序输出温度转换】");
for(int TempF=300;TempF>=0;){
double TempC=(5.0/9.0)*(TempF-32);
System.out.printf(TempF+"\t"+"%.1f"+"\n",TempC);
TempF=TempF-20;
}
}
}
练习2:
打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身。例如:153 是一个"水仙花数",因为153=1的三次方+5的三次方+3的三次方。
代码:public class ShuiHua{
public static void main(String argv[]){
System.out.println("【输出水仙花数】");
for(int i=100;i<1000;i++){
int hundreds=i/100;
int tens=i/10%10;
int ones=i%10;
int sum=hundreds*hundreds*hundreds+tens*tens*tens+ones*ones*ones;
if(sum==i){
System.out.println(sum);
}
}
}
}
练习3:
求1+2!+3!+...+20!的和
代码:public class JieCheng{
public static void main(String argv[]){
System.out.println();
System.out.println("求1+2!+3!+...+20!的和");
System.out.println();
long sum=0,x=1;
for(int i=1;i<=20;i++){
x=x*i;
sum=x+sum;
}
System.out.println(sum);
}
}
练习4:
求一个n阶方阵对角线元素之和。
代码:import java.util.*;
public class JuZhenSum{
public static void main(String argv[]){
//通过二维数组定义n阶方阵
final int Range = 9;
int arr[][] = new int[Range][Range];
int i,j,k=0;
for(i=0;i<Range;i++){
for(j=0;j<Range;j++){
arr[i][j]=k;
k++;
}
}
//System.out.println(Arrays.deepToString(arr));
//打印该方阵
System.out.println("++++++++++++++++++++++++++++++");
System.out.println("【方阵输出】");
int m,n;
for(m=0;m<Range;m++){
for(n=0;n<Range;n++){
System.out.print(arr[m][n]+"\t");
}
System.out.println();
}
//计算n阶方阵的对角线元素之和
System.out.println("++++++++++++++++++++++++++++++");
System.out.println("【对角线输出】");
int sum=0;
for(int p=0;p<Range;p++){
for(int q=0;q<Range;q++){
if(p==q){
System.out.print(arr[p][q]+"\t");
sum+=arr[p][q];
}
}
}
System.out.println();
System.out.println("++++++++++++++++++++++++++++++");
System.out.println("【对角线求和】"+"\n"+sum);
//计算n阶方阵的副对角线元素之和
System.out.println("++++++++++++++++++++++++++++++");
System.out.println("【副对角线输出】");
int sum1=0;
for(int p=0;p<Range;p++){
for(int q=0;q<Range;q++){
if(p==(Range-q-1)){
System.out.print(arr[p][q]+"\t");
sum1+=arr[p][q];
}
}
}
System.out.println();
System.out.println("++++++++++++++++++++++++++++++");
System.out.println("【副对角线求和】"+"\n"+sum1);
}
}
练习5:
输入一个一维数组,最大的与第一个元素交换,最小的与最后一个元素交换,输出数组。
代码:import java.util.Scanner;
public class EnterSort{
public static void main(String argv[]){
//定义输入
System.out.println("请输入要排序数组长度(n>=2):");
Scanner LenthIn = new Scanner(System.in);
int lenth = LenthIn.nextInt();
int len = lenth;
System.out.println("请输入该数组:");
Scanner EnterIn = new Scanner(System.in);
int arr[] = new int[lenth];
for(int i=0;i<lenth;i++){
arr[i] = EnterIn.nextInt();
}
//排序操作:最大的与第一个元素交换,最小的与最后一个元素交换
int arrCopy[] = arr;
int temp=0;
int change=1;
for(int m=0;m<lenth && change==1;m++){
change=0;
for(int n=0;n<lenth-1;n++){
if(arrCopy[n] > arrCopy[n+1]){
temp = arrCopy[n];
arrCopy[n] = arrCopy[n+1];
arrCopy[n+1] = temp;
change=1;
}
}
}
int x=0;
if(len == 2){ //数组长度等于2时的情况
temp = arrCopy[x];
arrCopy[x] = arrCopy[1];
arrCopy[1] = temp;
}else{ //数组长度大于2时的情况
temp = arrCopy[0];
arrCopy[0] = arrCopy[lenth-1];
arrCopy[lenth-1] = temp;
}
for(int i=0;i<lenth;i++){
System.out.print(arrCopy[i]+" ");
}
}
}