Java课程设计_第1页
Java课程设计_第2页
Java课程设计_第3页
Java课程设计_第4页
Java课程设计_第5页
已阅读5页,还剩14页未读 继续免费阅读

下载本文档

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

文档简介

1、学号技大学城市学院课程设计报告课程设计名称JAVA程序设计课程设计信息工程学部软件工程指导教师2017 年6月 23日课程设计评分表评分标准:1. 学生是否严格遵守课程设计纪律,按照规定时间完成设计任务(占30%)2.程序设计的质量与规范:(占40%)(1)任务书上的题目是否完成,并选做了ACM题目成功提交的ACM题目的数题及难度 是否采用了良好的设计方法,独立完成程序设计 程序是否运行正常,未见运行错误3.课程设计报告书的质量与规范(占30%)教师评分:1.学生出勤得分A.优 B.C.D.及格E.不及格2. 程序设计得分A.优 B.C.D.及格E.不及格3. 设计报告得分A.优 B.C.D.

2、及格E.不及格总分: 教师评语:根据该生在课程设计期间,是否严格遵守课程设计纪律,按照规定时间完成设计任务,完成的程序设计的质量与规范,提交的课程设计报告书的质量与规范等多方面的评分,该生本次课程设计的评分为:教师签名: 日期:年 月 日JAVA编程课程设计指导书学时:1周,学分:11 .课程设计目的:JAVA编程课程设计属于软件开发类课程设计。该课程设计培养学生JAVA熟练应用当前主流的 JAVA软件开发语言,检验软件的设计、编码与测试,具备较强的 语言软件开发能力。2.课程设计方式:(1) JAVA编程课程设计方式采取 ACM测试的方式,利用所学的面向对象程序设计 (JAVA) 知识,培养

3、学生具有分析应用问题的能力,能够独立完成应用程序的编制与调试工作。(3)每个同学必须完成 8-12道题,每题写出解题报告,解题报告内容:.题目标题 .题目描述 .解题思路 .源码 .小结3.课程设计平台:eclipse 或Myeciipse4. 课程设计考核方式(1)学生独立提交软件设计作品和“课程设计报告书”,指导教师根据学生组提交的软件设计作品和“课程设计报告书”的质量,为学生组评定“优”“良”“中”“及格”或“不及格”;(2)根据各组学生所选题目的难易程度以及验收结果,为学生评定“优”“良” “中”“及格”或“不及格”。,课程设计任务(功能)“课程设计报告书”包括:课程设计项目名称,课程

4、设计任务 说明及功能模块图,数据库设计,各模块功能说明,使用的算法描述(如果需使用算法), 各模块界面设计,各模块中关键代码段功能说明与代码行注释,测试说明,参考文献等。5.参考文献1张思民.Java语言程序设计(第2 版)2姜华.Java项目实战教程M.北京:3陈喧.Java程序设计教程M.北京:M.北京:清华大学出版社,清华大学出版社,清华大学出版社,4美Echel,B .Java编程思想(第四版)M.北京:机械工业出版社,20075 Michael Main.数据结构:Java语言描述(第二版)(国外经典计算机科学教材)M.北京:中国电力出版社,2007* throws lOExce p

5、ti on1星系炸弹1.1问题描述在X星系的广袤空间中漂浮着许多 X星人造“炸弹”,用来作为宇宙中的路标。每个炸弹都可以设定多少天之后爆炸。比如:阿尔法炸弹2015年1月1日放置,定时为15天,贝陀在2015年1月16日爆炸。有一个贝塔炸弹,2014年11月9日放置,输入定时天数,例如定时为1000天,请你计算它爆炸的准确日期。请填写该日期,格式为yyyy-mm-dd ?即4位年份2位月份2位日期。比如:2015-02-19输入:?输入炸弹引爆延迟的天数。输出:对于每个输入天数,输出符合题目要求的格式的日期。样例输入:1000样例输出:2017-08-051.2解题思路1,分析题意可知,本题是

6、求一个日期,想到了Calendar。114712,3,4,用add方法设置偏移值,偏移值由键盘输入获取scanner 。5,用getTime获取偏移后的 Date对象。输入的数据是这个日期距离2014-11-09的天数,想到了 add方法。用set设置起始日期2014-11-09 11月在代码中表现为10。6,自定义格式把对象转换成字符串输出,格式为:yy-MM-dd。1.3代码P ublic class Mai n /* p aram args*/P ublic static void main( Stri ng args) throws IOExce pti on .11 表示12月。日是

7、用131的整数表示。小时用023的整数表示。2小光棍数2.1问题描述为了迎接一年一度光棍节的到来,让我们一起来看看小光棍数吧。倘若一个数的三次方最后三位数是111,这样的数称为小光棍数。从0开始计数,第一个小光棍数是,请问第m个小光棍数是多少。输入第一行一个整数T表示有T组测试数据接下来T行每行有一个数m输出输出第m个小光棍数每次输出占一行样例输出样例输出解题思路1, 分析题意可知,第一次输入的数据表示测试数据有几组,也就是控制循环的次数。2, 第二次输入的数据表示查找第几个小光棍数,想到了定义一个变量作为计数器,查 找到一个记一次数,计数器的值等于输入的数据就停止查询, 并输出查到的数据。3

8、, 循环控制着一个查找功能,数字的三次方要保证是三位数,不是就不用查找了,用if条件语句控制。直接把三次方处理后的数据对1000取余数得出的值就是最后三位,如果是111就满足条件,这个数字就是小光棍数。代码P ublic class Mai n p ublic static void main( Stri ng args) while( n-!=0)小结这种特殊数字的查找原本在不用数学方法的情况下,计算量十分大,但是对计算机而言却不是很大,以后这种数据找不到规律可以直接用java写一个程序快速计算。但要注意对循环的控制。3零起点学算法12求2个日期之间的天数2.2问题描述水题输入输入2个日期,

9、日期按照年月日,年月日之间用符号-隔开(题目包含多组数据)输出求出这2个日期之间的天数(不包括自身),每组测试数据一行样例输入:2011-1-12011-1-5样例输出:2.3解题思路1,分析题意可知,本题使用了日历,想到了Calendar。分别用两个字符串接收输入的数据,并且把接收到的字符串中的年、月、日切割出2,来,想到了 split 方法。3,分别用set设置起始日期和终止日期。4,5,分别用getTime方法获取Date对象,再把 Date对象转化为毫秒值。用后一个毫秒值减前一个毫秒值,并把毫秒转化成天打印。2.4代码P ublic class Main/* p aram args*/

10、p ublic static void main(String args) .+(1+2+3+.+n)输入输入正整数n (多组数据)输出样例输入:2样例输出:42.5解题思路1,看到这个式子想到了循环,把一个数据从1累加到n。但这只是完成了一个小括号内部的运算。2,值减一,继续思考,想到了递归,定义一个方法add实现累加功能,运算完一次就把传入的把每次累加后的值相加。3,如果n的值等于1,就停止递归,把最终的和返回。2.6代码P ublic class Mainp ublic static void main( Stri ng args)int sum=0;int a=0;for(i nt i

11、=1;i<=n ;i+) a=a+i;sum=sum+a;2.7小结1.?递归一定要有结束条在方法中自己调用了自己,就要想到递归。使用递归要注意: 件。2.递归次数不能过多,容易引起内存溢出。5零起点学算法35再求多项式(含浮点)问题描述输入一个整数n,计算?1 + 1/( 1-3)+1/( 1-3+5)+.+1/(1-3+5-.+2n-1)的值输入输入一个整数n (多组数据)输出出 1+1/(1-3)+1/据一行)(1-3+5)+.+1心-3+5-.+2n-1)的值,保留2位小数(每组数样例输入:11,建立一个名称为fun 的方法计算 1-3+5-.+2n-1的值。operation

12、的方法计算 1+1/ ( 1-3)+1/ ( 1-3+5)+.+1/2,建立一个名称为(1-3+5.+2n+1)的值,分母的值调用 fun方法得到,分子为1,运用递归知识,和上一题思想一样。3,调用operation方法得到返回值,将返回值以保留两个小数的固定格式输出。P ublic class Mainp ublic static void main( Stri ng args)int a;double b=0;double c=0;int flag=1;for(i nt i=1;i<=a;i+)c=c+flag*(2*i-1);flag=-flag;在方法中自己调用了自己,就要想到递

13、归。使用递归要注意:件。2.递归次数不能过多,容易引起内存溢出。以固定格式输出可以考虑态方法format 方法。1.?递归一定要有结束条String类中的静6 3n+1问题问题描述任给一个正整数n,如果n为偶数,就将它变为n/2,如果为奇数, 3n +1)。不断重复这样的运算,经过有限步后,一定可以得到则将它乘3加1 (即1。输入:输入1个正整数n (n<=10人10)(多组数据)输出:输出变化的次数(每组数据一行)样例输入:3样例输出:7解题思路1,获取输入的数据,判断是否满足*=10人10。2,定义一个变量count为计数器。用if判断n为奇数还是偶数,按各自要求分别处理数据,直到n

14、值为1。每处理一3,次count就加1,循环结束打印count。代码p ublic class Main p ublic static void main(Stnng args) int count=0;while(!(num=1)if(num=0)break;if(num%2=0)num=num/2;else num=num*3+1;count+;小结凡是遇到和次数有关的问题, 就要想到能否定义一个计数器来记录次数,合适的定义变量可以很好地控制和显化代码的执行。7基础练习Huffuman树问题描述Huffman树的构造过程。Huffman树在编码中有着广泛的应用。在这里,我们只关心给出一列数

15、pi=p0, p1,pn-1,用这列数构造 Huffman树的过程如下:1.找到pi中最小的两个数,设为pa和pb,将pa和pb从pi中删除掉,然后将它们的和加入到pi中。这个过程的费用记为pa + pb。2.重复步骤1,直到pi中只剩下一个数。Huffman树的总费用。在上面的操作过程中,把所有的费用相加,就得到了构造本题任务:对于给定的一个数列,现在请你求出用该数列构造Huffman树的总费用。例如,对于数列pi=5, 3, 8, 2, 9,Huffman树的构造过程如下:1.找到5, 3, 8, 2, 9和5加入,得到5, 8, 9, 5中最小的两个数,分别是 2和3,从pi中删除它们并

16、将 ,费用为5。2.找到5, 8, 9, 510加入,得到8, 9, 10,中最小的两个数,分别是 5和5,从pi中删除它们并将和 费用为10。3.找到8, 9, 10加入,得到10, 17,费用为17。中最小的两个数,分别是8和9,从pi中删除它们并将和174.找到10, 17中最小的两个数,分别是 10和17,从pi 加入,得到27,费用为27。中删除它们并将和27输入5.现在,数列中只剩下一个数27,构造过程结束,总费用为5+10+17+27=59。输入的第一行包含一个正整数n (n<=100)。接下来是n个正整数,表示 p0, p1,pn-1,每个数不超过1000。输出输出用这些

17、数构造 Huffman树的总费用。样例输入:样例输出591.分析题意知道先输入数列的总数,然后输入数列,可以用数组进行存储数列。2.用循环,当数列不为空,对数组进行排序,进行运算,直至队列为空,输出结果。P ublic class O p ublic static void main( Stri ng args)throws Exce pti onScanner a while () int num =();in t huff = new intnu m;for (int i = 0; i < num; i+)huffi =();int sum = 0;int k = 0;while (num > 1) k = huff0 + huff1;sum = sum + k;huff0 = k;nu m-;Java中可以直接调用排序,很方便。总结通过这次课程设计,我学到了更多的java的知识,很多类库能很好的解决我需要的功能,这使我很有兴趣来学习java,上课时候的还可以听懂,但是在实验过程中我遇到了许多的问题,总是找不到头绪,让自己不知所措,但通过查阅api文档,使我有了很大进步,这让我认识到学习 Java 一定要多多练习,才能巩固知识。还好学校安排了课程设计这门课,在这个时候

温馨提示

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

评论

0/150

提交评论