- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
for(year=m;year<=n;year++) { if((year%4==0&&year%100!=0)||year%400==0) System.out.println(year);
} } }
3. 简单计算器(选做) 40033 输入一个正整数 repeat (0<repeat<10),做 repeat 次下列运算: 程序模拟简单运算器的工作:输入一个算式,遇等号"="说明输入结束,输出结果。 假设计算器只能进行加减乘除运算,运算数和结果都是整数,4 种运算符的优先级相同,按从左到右 的顺序计算。
或:
if(a==0) { if(b==0) { if(c==0)
System.out.println("a=b=c=0,meaningless"); else
System.out.println("a=b=0,c!=0,error"); } else { x1=-(double)c/b; System.out.println("x="+Math.round(x1*100)/100.0); } } else { d=b*b-4*a*c; if(d>=0) { x1=(-b+Math.sqrt(d))/(2*a); x2=(-b-Math.sqrt(d))/(2*a); System.out.println("x1="+Math.round(x1*100)/100.0); System.out.println("x2="+Math.round(x2*100)/100.0); } else { x1=-(double)b/(2*a); x2=Math.sqrt(-d)/(2*a);
(1)a=b=c=0,meaningless
(2)a=b=0,c!=0,error
(3)x=值
(值为-c/b)
(4)x1=值 1
(值 1 为(-b+Math.sqrt(d))/(2*a))
x2=值 2
(值 2 为(-b-Math.sqrt(d))/(2*a))
(5)x1=值 1+值 2i
x2=值 1-值 2i (值 1 为-b/(2*a),值 2 为 Math.sqrt(-d)/(2*a))
例:括号内是说明
输入:
2
(repeat=2)
4 1 7 4 1 4 8 3 6 1 6 1 2 0 7 8 9 (n=4)
2 1 7 4 1 (n=2)
输出:
a[2][1]=6
NO
import java.util.Scanner; public class Test60019{
public static void main(String []args){ int ri, repeat;
实验 13 未做和选做题
1. 求一元二次方程的根 输入一个正整数 repeat (0<repeat<10),做 repeat 次下列运算:
输入参数 a,b,c,求一元二次方程 a*x*x+b*x+c=0 的根,结果保留 2 位小数(如果答案为 3.50,则直接显示为 3.5)。
按情况分别输出以下内容(文字中的标点为西文标点,无空格。括号内为说明):
输入输出示例:括号内为说明
输入:
5
(repeat=5)
000
(a=0,b=0,c=0)
001
(a=0,b=0,c=1)
025
(a=0,b=2,c=5)
21 89 35 (a=21,b=89,c=35)
223
(a=2,b=2,c=3)
输出:
a=b=c=0,meaningless
a=b=0,c!=0,error
例:括号内是说明 输入 2 (repeat=2) 15 + 2 / 3 = (数字与运算符之间有一空格) 1 + 2 * 10 - 10 / 2 = (数字与运算符之间有一空格) 输出 5 10
import java.util.Scanner; public class T40033{
public static void main(String args[]) { int ri, repeat; int op1, op2, res; char operator; Scanner in=new Scanner(System.in); repeat=in.nextInt(); for(ri=1; ri<=repeat; ri++){ op1=in.nextInt(); operator=(in.next()).charAt(0); /*---------*/ res=op1; while(operator!='=') { op2=in.nextInt(); switch(operator) { case '+': res+=op2;break; case '-': res-=op2;break; case '*': res*=op2;break; case '/': res/=op2;break; } operator=(in.next()).charAt(0); } System.out.println(res); }
if(a[row][j]>a[row][col]) col=j;
//再判断a[row][col]是否是第col列中的最小值 flag=true; for(k=0;k<n;k++)
if(a[k][col]<a[row][col]){ flag=false; break; //若有比a[row][col]小的,可知它不是鞍点,可结束循环
int i,j,k,row,col,n,a[][]; boolean flag; Scanner in=new Scanner(System.in); repeat=in.nextInt(); for(ri=1; ri<=repeat; ri++){
n=in.nextInt(); a=new int[n][n]; for (i=0;i<n;i++)
System.out.println("x1="+Math.round(x1*100)/100.0+"+"+Math.round(x2*100 )/100.0+"i");
System.out.println("x2="+Math.round(x1*100)/100.0+"-"+Math.round(x2*100 )/100.0+"i");
} }
2. 输出 m~n 之间的所有闰年(未做) 输入一个 repeat(1<repeat<10)),做 repeat 次下列运算: 输入正整数 m 和 n(1900<=m<=n<=2100),分别代表年份的起止值,输出该范围内所有的闰年。 判断闰年的条件是:能被 4 整除但不能被 100 整除,或者能被 400 整除。 输出使用语句 System.out.println(year);
} }
4. 找鞍点(选做) 输入一个正整数 repeat (0<repeat<10),做 repeat 次下列运算: 输入 1 个正整数 n 和 n 阶方阵 a 中的元素,如果找到 a 的鞍点(鞍点的元素值在该行上最大, 在该列 上最小), 就输出它的下标, 否则,输出"NO"(设 a 最多有 1 个鞍点)。
x=-2.5
x1=-0.44
x2=-3.8
x1=-0.5+1.12i
x2=-0.5-1.12i
import java.util.Scanner; public class Test30009{
public static void main(String args[]){ int repeat, ri; int a,b,c,d; double x1,x2; Scanner in=new Scanner(System.in); repeat=in.nextInt(); for(ri = 1; ri <= repeat; ri++){ a=in.nextInt();b=in.nextInt();c=in.nextInt(); /*---------*/
} }
} } }
说明:为防止出错,在编程前应考虑周全 当 a=b=c=0 时,方程有无数解; 当 a=b=0,c!=0 时,方程无解; 当 a=0,b!=0 时,方程解为 x=-c/b; 当 a!=0 时,求:d=b*b-4*a*c
若 d>=0,有两个不同实根:x=(-b±Math.sqrt(d))/(2*a) 若 d<0,有两个不同复根:x=-b/(2*a)±Math.sqrt(-d)/(2*a)i
if(a==0&&b==0&&c==0)
System.out.println("a=b=c=0,meaningless"); else if(a==0&&b==0&&c!=0)
System.out.println("a=b=0,c!=0,error"); else if(a==0&&b!=0){
x1=-(double)c/b; System.out.println("x="+Math.round(x1*100)/100.0); } else { d=b*b-4*a*c; if(d>=0) { x1=(-b+Math.sqrt(d))/(2*a); x2=(-b-Math.sqrt(d))/(2*a); System.out.println("x1="+Math.round(x1*100)/100.0); System.out.println("x2="+Math.round(x2*100)/100.0); } else { x1=-(double)b/(2*a); x2=Math.sqrt(-d)/(2*a);
输入输出示例:括号内是说明 输入: 2 2000 2017 2030 2040 输出
2000 2004 2008 2012 2016 2032 2ቤተ መጻሕፍቲ ባይዱ36 2040
import java.util.Scanner; public class Test40034{
public static void main(String []args){ int year,m,n,repeat,ri; Scanner in=new Scanner(System.in); repeat=in.nextInt(); for(ri=1;ri<=repeat;ri++){ m=in.nextInt(); n=in.nextInt(); /*---------*/
for (j=0;j<n;j++) a[i][j]=in.nextInt();
/*---------*/ flag=true; row=0; col=0;//不写这些,就通不过编译 for(i=0;i<n;i++){
//先在第i行中找出该行的最大值 row=i; //row保存最大值的行坐标 col=0; //col保存最大值的列坐标,假设第i行第0列元素为最大 for(j=1;j<n;j++)
} if(flag)break; //找到1个鞍点后就不用再找了 }
if(flag) System.out.println("a["+row+"]["+col+"]="+a[row][col]); else System.out.println("NO"); } } }
System.out.println("x1="+Math.round(x1*100)/100.0+"+"+Math.round(x2*100 )/100.0+"i");
System.out.println("x2="+Math.round(x1*100)/100.0+"-"+Math.round(x2*100 )/100.0+"i");