浙大java语言程序设计编程答案8_第1页
浙大java语言程序设计编程答案8_第2页
浙大java语言程序设计编程答案8_第3页
免费预览已结束,剩余1页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、实验 9-1 Method 的使用 (二 )1. 将一个整数逆序输出输入一个正整数 repeat (0<repeat<10),做 repeat 次下列运算: 输入一个整数,将它逆序输出。要求定义并调用函数 reverse(number),它的功能是返回 number 的逆序数。例如 reverse(12345)的返 回值是 54321。例:括号内是说明输入4 (repeat=4)123456 -100 -2 99输出654321-1-299import class Test50009public static void main(String args) int ri,repeat

2、; long n, res;Scanner in=new Scanner; repeat=(); for(ri=1;ri<=repeat;ri+) n=();res=reverse(n);static long reverse(long number)int flag=1;long a=0,digit; if(number<0) flag=-1; number=-number; while(number>0) digit=number%10; / 分离出个位数字 a=a*10+digit; / 形成当前的逆序数 number=number/10;return flag*a;2

3、. 十进制转换二进制输入一个正整数 repeat (0<repeat<10),做 repeat 次下列运算:输入 1 个正整数 n,将其转换为二进制后输出。要求定义并调用函数 dectobin(n) ,它的功能是输出 n 的二进制。例如,调用 dectobin(10),输出 1010 输出语句: /t 为某位二进制数例:括号内是说明输入:3 (repeat=3)151000输出:111111001000import class Test50010public static void main(String args)int ri,repeat;int i,n;Scanner in=

4、new Scanner;repeat=(); for(ri=1;ri<=repeat;ri+) n=();dectobin(n);static void dectobin(int n)String t="" / 保存二进制数 do t=n%2+t; /n 除 2 后的余数拼接到 t 的前面 n=n/2; / 获得除 2 后的商while(n>0);/ 本方法无返回值,需要在方法体中输出结果说明:本题中方法 dectobin(n) 的输出虽然与要求有所出入,但上传是正确的3. 用函数求三个数的最大值输入一个正整数 repeat (0<repeat<10

5、),做 repeat 次下列运算:输入三个整数 a、 b 和 c,输出其中较大的数。要求定义和调用函数 max(a, b, c)找出 a、b、c 中较大 的数,函数形参 a、b 和 c 的类型是 int 。输入输出示例:括号内是说明输入3(repeat=3)输入:5 8 9(a=5, b=8)-1 -10-5 (a=-1, b=-10)1 1 1(a=1, b=1)输出: max(5,8,9)=9 max(-1,-10,-5)=-1 max(1,1,1)=1import class Test50011 public static void main(String args) int ri, r

6、epeat;int a,b,c,maximun;Scanner in=new Scanner; repeat=();for (ri=1; ri<= repeat; ri+) a=();b=();c=();maximun=maximun(a,b,c);"max("+a+","+b+","+c+")="+maximun);static int maximun(int a,int b,int c) int max; max=a;if(max<b)max=b;if(max<c)max=c;return m

7、ax;实验 9-2 一维数组的使用4. 求平均值 输入一个正整数 repeat (0<repeat<10),做 repeat 次下列运算: 输入一个正整数 n (1<n 1,0)再输入 n 个整数,输出平均值。例:括号内是说明输入2 (repeat=2)3 1 2 -65 12 2 5 4 0 输出 aver= aver=import class Test60001public static void main(String args)int ri, repeat;int i, n, sum,a; float aver;Scanner in=new Scanner;repea

8、t=();for(ri=1; ri<=repeat; ri+)n=();a=new intn; for(i=0; i<n; i+) ai=(); / 这个循环输入数组各元素sum=0;for(i=0; i<n; i+) / 这个循环实现累加 sum+=ai;aver=(float)sum/n; / 求平均值,注意要先把 sum 转换成 float ,再计算"aver="+aver);5. 求最大值及其下标0 开始)输入一个正整数 repeat (0<repeat<10),做 repeat 次下列运算:输入一个正整数 n (1<n 1,0)

9、再输入 n 个整数,输出最大值极其下标(设最大值惟一,下标从 例:括号内是说明输入3 (repeat=3)3 1 6 4 3 10 8 1(最大值 6 的下标是 1)(最大值 10 的下标是 0)(最大值 5 的下标是 2)5 1 2 5 4 0 输出 max=6,index=1 max=10,index=0 max=5,index=2 import class Test60002public static void main(String args) int ri, repeat;int i, index, n, a;Scanner in=new Scanner; repeat=();for

10、(ri=1; ri<=repeat; ri+) n=(); a=new intn ; for(i=0; i<n; i+) ai=();index=0; / 用 index 保存最大数的下标,开始假设 a0 是最大数 for(i=1; i<n; i+) if(aindex<ai) index=i;/ai 与当前最大数 aindex比较,若 ai更大, index变为 i"max="+aindex+",index="+index);6. 逆序输出 输入一个正整数 repeat (0<repeat<10),做 repeat

11、次下列运算: 输入一个正整数 n (1<n 1,0)再输入 n 个整数,按逆序输出这些数。例:括号内是说明 输入2 (repeat=2)4 10 8 1 25 1 2 5 4 0 输出2 1 8 100 4 5 2 1import class Test60003public static void main(String args) int ri, repeat;int i, n, temp,a;Scanner in=new Scanner; repeat=();for(ri=1; ri<=repeat; ri+) n=();a=new intn; for(i=0; i<n;

12、 i+) ai=();for(i=0; i<n/2; i+) /ai 与 an-1-i 交换,注意交换次数 temp=ai;ai=an-1-i; an-1-i=temp;for(i=0; i<n; i+);7. 交换最小值和最大值输入一个正整数 repeat (0<repeat<10),做 repeat 次下列运算:输入一个正整数 n,再输入 n 个整数,将最小值与第一个数交换,最大值与最后一个数交换,然后输出 交换后的 n 个数。例:括号内是说明 输入3 (repeat=3)5 4 3 5 1 24 1 5 6 75 5 4 3 2 1输出1 3 2 4 51 5 6 71 4 3 2 5 import class Test60004public static void main(String args) int ri, repeat;int i, index, n, t,a;Scanner in=new Scanner; repeat=();for(ri=1; ri<=repeat; ri+) n=();a=new intn;for(i=0; i<n; i+) ai=();index=0; / 找最小数for(i=0; i<n; i+)if(aindex>ai) index=i;t

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论