Java历次实验课代码
更新时间:2023-10-06 10:52:01 阅读量: 综合文库 文档下载
Java历次实验课代码
1.求出2-1000内的所有个位为3或7的素数,并按每行5列的格式输出。 package first_work;
public class First_work { public static void main(String[] args) { int i,m; int j=0; for(i=2;i<=1000;i++) { for(m=2;m<=Math.sqrt(i);m++) {if(i%m==0)break;} if(m>Math.sqrt(i)&&(i==3||i==7)) { System.out.print (i+\ j++; if(j!=0&&j%5==0) { System.out.println(); } }; } } }
2.教材71页15题,增加以下内容:同时要求用选择排序、冒泡排序、插入排序实现,分别用不同的函数实现。 package first_work; public class Sort { public static void choose(int[] x) { for (int i=0; i int temp=x[j]; x[j]=x[j-1]; x[j-1]=temp; } } } } public static void main(String[] args) { int[] a={20,10,55,40,30,70,60,80,90,100}; int i,j,x,T=0; for( i=1;i<10;i++) for(j=0;j<9;j++) if(a[j]>a[j+1]) { T=a[j]; a[j]=a[j+1]; a[j+1]=T; } for(x=0;x<10;x++) { System.out.print(' '); System.out.print(a[x]); } System.out.print('\\n'); choose(a); for(x=0;x<10;x++) { System.out.print(' '); System.out.print(a[x]); } System.out.print('\\n'); insert(a); for(x=0;x<10;x++) { System.out.print(' '); System.out.print(a[x]); } } } 3.实现一个三行三列的矩阵和它的转置相加。package first_work; public class Matrix { public static void main(String[] args) { int [][]array= {{1, 2, 3}, {4, 5, 6}, {7, 8, 9}}; int i, j, t; int count=0; for (i = 0; i < 2; i++) { for (j = i + 1; j < 3; j++) { t = array[i][j]; array[i][j] = array[j][i]; array[j][i] = t; } } for (i = 0; i < 3; i++) { for (j = 0; j < 3; j++) { System.out.print(array[i][j] + \ count++; if(count!=0&&count%3==0) System.out.println(); } } for (i = 0; i < 3; i++) { for (j = 0; j < 3; j++) { System.out.print(array[i][j] + array[j][i]+\ count++; if(count!=0&&count%3==0)System.out.println(); } } } } 4.建立交通工具类TransTool,里面包含两个方法void run()和void brake(),然后建立它的Bike、Car以及Bus子类, 在各个子类中重写void run()和void brake()方法,在实现各个方法时只要输出一个自己定义的对应的提示信息即可。最后建立一个测试类MyTest, 该类中包含主函数,测试运行时的多态性。 package yao2; public class MyTest { public static void main(String[] args) { Transtools s = new Transtools(); s.run(); s.brake(); Car t = new Car(); t.run(); t.brake(); Bus w = new Bus(); w.brake(); w.run(); } } class Transtools { public void run() { System.out.println(\ } public void brake() { System.out.println(\ } } class Car extends Transtools { public void run() { System.out.println(\ } public void brake() { System.out.println(\ } } class Bus extends Transtools { public void run() { System.out.println(\ } public void brake() { System.out.println(\ } } 5.在工作目录中建立AAA.BBB.CCC包,在包CCC中建立一个名为Stack的public类,有两个私有成员变量:int[] stk和 int pos,分别表示创建的任意大小的堆栈和栈顶的索引,写出该类的构造函数、入栈函数void push(int x)、出栈函数int pop(), 另外,建立AAA.BBB.DDD包,在DDD包中定义一个测试类MyTest,其中包含主函数,测试Stack类的各个方法。 package AAA.BBB.CCC; public class Stack { int[] stk; int pos; public Stack(int[] stk, int pos) { super(); this.stk = stk; this.pos = pos; } public void push(int x) { if(pos<0) System.pause(); pos++; stk[pos]=x; for(int i=0;i package AAA.BBB.CCC.DDD; import AAA.BBB.CCC.*; public class MyTest extends Stack{ public MyTest(int[] stk, int pos) { super(stk, pos); } public static void main(String[] args) { int[]a={1,2,3,4,5,6,7,8,9}; int s=a.length; Stack m = new Stack(a, s); m.push(10); m.pop(); System.out.println(s); } } 6.查阅JAVA API文档,用StringBuffer类的相关方法实现如下字符串的操作: 用字符串“I'm a student.”构造一个StringBuffer类型的对象; 用该对象的相关方法显示这个字符串的长度; 用该对象的相关方法,在上述字符串的单词student前面插入一个单词good,形成一个新的字符串“I'm a good student.”,显示新串。 用该对象的相关方法,删除刚才插入的good,将字符串还原为原来的字符串“I'm a student.” 用该对象的相关方法,提取字符串“I'm a student.”中索引下标为奇数同时它的ASCII码也为奇数的字符,形成一个新的字符串; 用该对象的相关方法,在字符串“I'm a student.”的末尾追加一个新的字符串:“I study at Nantong University.”,显示新串. package yao3; public class Str { StringBuffer public static void main(String[] args) { StringBuffer s=new StringBuffer(\ int k=s.length(); System.out.println(k); s.insert(7, \ System.out.println(s); s.insert(1, 2, 3, 4); s.delete(7, 12); System.out.println(s); int h=s.lastIndexOf(\ System.out.println(h); int x=s.offsetByCodePoints(1, 3); System.out.println(x); String y=s.substring(2); System.out.println(y); String z = s.substring(3, 7); System.out.println(z); String w = s.toString(); System.out.println(w); CharSequence a =s.subSequence(3, 7); System.out.println(a); System.out.println(b); for(int i=1;i 7.编写一个函数实现两个三行三列的矩阵相乘,函数的形参是两个二维矩阵,函数的返回值是成绩的二维矩阵,在主函数中进行测试。 package third_4_22; public class Matrix { public int[][] Mul(int [][]a,int [][]b) { int[][]c=new int[3][3]; for(int i=0;i<3;i++) for(int j=0;j<3;j++) { c[i][j]=a[i][j]*b[i][j]; System.out.println(c[i][j]); } return c; } public static void main(String[] args) { int[][] x=new int[][]{{1,2,3},{4,5,6},{7,8,9}}; int[][] y=new int[][]{{1,1,1},{1,1,1},{1,1,1}}; Matrix w =new Matrix(); int [][]c=w.Mul(x, y); for(int i=0;i<3;i++) for(int j=0;j<3;j++) System.out.print(c[i][j]); int []=w.Mul(x, y); w.Mul(x, y); } } 8.用二维for-each语句输出二维数组中每个元素的值。 package third_4_22; public class Ergodic { public static void main(String[] args) { int array[]={12,23,34,45,56,67,78}; for(int a:array) System.out.print(a+\ } } 9.在工作目录中建立AAA.BBB.CCC包,在包CCC中建立一个名为Queue队列类,有三个私有成员变量:int[] que, int front,int rear,分别表示创建的任意大小的队列、队列的头部和队列尾部的索引,写出该类的构造函数、入队函数void insert(int x)、出对函数int remove(), 另外,建立AAA.BBB.DDD包,在DDD包中定义一个测试类MyTest,其中包含主函数,测试Queue类的各个方法。 package AAA.BBB.CCC; public class Queue { int []Queue; int front; int rear; public Queue(int[] queue, int front, int rear) { super(); Queue = queue; this.front = front; this.rear = rear; } public void insert(int x) { rear++; Queue[rear]=x; } public int remove() { int n=Queue[front]; front++; return n; } } package AAA.BBB.DDD; import AAA.BBB.CCC.Queue; public class MyTest extends Queue{ public MyTest(int[] queue, int front, int rear) { super(queue, front, rear); } public static void main(String[] args) { int []a={1,2,3,4,5,6}; Queue q = new Queue(a, 0, 5); q.insert(19); int m = q.remove(); System.out.println(m); } } 10.建立交通工具抽象类TransTool,里面包含两个抽象方法void run()和void brake(),然后建立它的Bike、Car以及Bus子类, 在各个子类中重写void run()和void brake()方法,在实现各个方法时只要输出一个自己定义的对应的提示信息即可。最后建立一个测试类MyTest, 该类中包含主函数,测试运行时的多态性。 package one; abstract public class TransTool { public static void main(String[] args) { Transtools s = new Car(); s.run(); s.brake(); Car t = new Car(); t.run(); t.brake(); s = new Bus(); s.brake(); s.run(); } } class Transtools { public void run() { System.out.println(\ } public void brake() { System.out.println(\ } } class Car extends Transtools { public void run() { System.out.println(\ } public void brake() { System.out.println(\ } } class Bus extends Transtools { public void run() { System.out.println(\ } public void brake() { System.out.println(\ } } 11.建立交通工具接口TransTool,里面包含两个方法void run()和void brake(),然后分别建立Bike、Car以及Bus类实现该接口,在实现各个方法时只要输出一个自己定义的对应的提示信息即可。最后建立一个测试类MyTest, 该类中包含主函数,测试接口回调。 package two; public interface TransTool { public void run(); public void brake(); } package two; public class MyTest implements TransTool { public void run() { System.out.println(\ } public void brake() { System.out.println(\ } public static void main(String[] args) { MyTest s = new MyTest(); s.run(); s.brake(); } } 12.建立学生Student接口,包含方法查询学号方法void get_Snumber()和查询班级方法void get_Class(),建立Teacher接口,包含方法查询工号方法void get_Wnumber()和查询工资方法void get_Salary(), 建立一个在职研究生类Poststudent,实现这两个接口。最后建立一个测试类MyTest, 该类中包含主函数,测试接口回调。 package three; public class Poststudent implements Student, Teacher { public void get_Wnumber() { System.out.println(\工号:0001\ } public void get_Salary() { System.out.println(\工资:8000\ } public void get_Snumber() { System.out.println(\学号:1313012002\ } public void get_Class() { System.out.println(\班级:计师131\ } } package three; public interface Student { void get_Snumber(); void get_Class(); } package three; public interface Teacher { void get_Wnumber(); void get_Salary(); } package three; public class MyTest { public static void main(String[] args) { Teacher t=new Poststudent(); Student s =new Poststudent(); s.get_Class(); t.get_Salary(); s.get_Snumber(); t.get_Wnumber(); } } 13.在工作目录中建立AAA.BBB.CCC包,在包CCC中建立一个名为Stack的类,有三个私有成员变量:char[] stk、int pos以及int size,分别表示创建的堆栈、栈顶的索引以及栈的容量大小,写出该类的构造函数、入栈函数void push(int x)、出栈函数int pop(), 取栈顶元素 (元素不出栈)函数int peek()以及判断栈是否为空栈的函数void isEmpty();另外,建立AAA.BBB.RRR包,在包中建立一个字符串逆序类Myreverser,该类包括两个私有数据成员String input和String output,分别表示逆序前和逆序后的字符串,请写出Myreverser类的构造函数public Myreverser(String myinput)以及将字符串逆序函数public String reverse(),实现该逆序函数时要求使用AAA.BBB.CCC包中的Stack的类来做,算法思想是按照堆栈操作的先进后出的原则,将一个字符串的每个字符取出后依次入栈,所有字符都入栈完毕后再将栈中字符依次出栈后连接,即为逆序字符。注意,取字符串中索引为index的字符可以使用系统类库中String类的方法:public char charAt(int index),具体可以查阅API文档。最后,建立AAA.BBB.DDD包,在DDD包中定义一个测试类MyTest,其中包含主函数,使用Stack类和Myreverser类测试字符串的逆序功能。 源代码: package AAA.BBB.DDD; import AAA.BBB.CCC.*; import AAA.BBB.RRR.Myreverser; public class MyTest { private static final String input = null; private static final String output = null; public static void main(String[] args) { TODO Auto-generated method stub char[]a={'a'}; for(int i=-1;i<4;i++) { Stack m=new Stack(a,i,6); m.push('o'); m.push('w'); } String s1=new String(a); System.out.println(s1); Myreverser k=new Myreverser(\ k.reverse(); } package AAA.BBB.CCC; public class Stack { char [] stk; int pos; int size; public Stack(char[] stk, int pos, int size) { super(); this.stk = stk; this.pos = pos; this.size = size; } public void push(char x) { if(pos==size-1) System.out.println(\栈满,无法入栈!!!\ pos++; stk[pos]=x; for(int i=0;i package AAA.BBB.RRR; import java.lang.String; import AAA.BBB.CCC.Stack; public class Myreverser { String input; String output; public Myreverser(String input, String output) { super(); this.input = input; this.output = output; } public String reverse() { char []stk={'a'}; Stack s=new Stack(stk, 0, 6); String str1=new String(); String str2=new String(stk); int k=str2.length(); System.out.println(k); Myreverser k=new Myreverser(\ for(int i=0;i<6;i++) { char x=str2.charAt(i); System.out.print(x); } s.push('a'); String s1=new String(); char[] arr={'a','b','c'}; char[] arr1={}; String s2=new String(arr); for(int i=2;i>=0;i--) { char x=s2.charAt(i); System.out.print(x); } return s2; } } 14.在工作目录中建立AAA.BBB.CCC包,在包CCC中建立一个名为MyStack MyStack return stk[pos]; } public E pop() { if(pos==-1) { System.out.println(\栈空,无法出栈\ } pos--; return stk[pos]; } public void Show() { if(pos<=-1) System.out.println(\栈空\ else { System.out.print(\栈里含有的元素为\ for(int i=pos;i>=0;i--) System.out.print(stk[i]+\ } } } package AAA.BBB.DDD; import AAA.BBB.CCC.MyStack; class Student{ public int b; System.out.println(\} public class MyTest { public static void main(String[] args) { Integer [] a=new Integer[3]; MyStack MyStack 15.利用jdk提供的类库中的Stack public class MyTest_2 { public static void main(String[] args) { Stack 16.利用jdk提供的类库中的Scanner类从键盘输入任意一组字符串,要求在字符串的中间位置插入一个字串:hello,使用jdk提供的类库中的StringBuffer类。 package three; import java.util.Scanner; public class StrFanxing { public static void main(String[] args) { char ss; Scanner cin=new Scanner(System.in); String str,b=\ str=cin.nextLine(); char []s; s=new char[str.length()]; for(int i=0;i for(int j=0;j 17.利用jdk提供的类库中的ArrayList类建立一个字符串的动态数组,数组中的所有元素要求从键盘输入,数组建立好了以后,要求当输入一个指定的字符串时,在刚才的数组中查找该字符串,如果找到,将该字符串元素删除,如果找不到,则给出提示信息。 package four; import java.util.*; public class Array { public static void main(String[] args) { ArrayList } 18.设计一个程序,不考虑程序代码的算法意义,只要求程序代码可能产生 NullPointerException异常、ArithmetricException异常、ArrayIndexOutofBoundException异常以及NubmerFormatException异常,并通过try-catch语句捕获以上各种异常,做不同的处理。 package one; public class wrong { public static void main(String[] args) { try{ String s=null; int l=s.length(); int []a=new int [6]; a[8]=89; int k=8/0; String str =\ double d= Double.parseDouble(str); }catch(NullPointerException e) { System.out.println(\空指针!\ }catch(ArrayIndexOutOfBoundsException e) { System.out.println(\越界!\ }catch(ArithmeticException e) { System.out.println(\除数为0!\ }catch(NumberFormatException e) { System.out.println(\转换异常!\ } } } 19.自定义一个异常类MyException, 重写他ToString() 方法,给出个性化的异常显示信息。当从键盘输入一个字符串,当该字符串中包含数字字符时,抛出一个MyException异常,否则不抛出异常。用两种方法完成该题,第一种方法要求异常的抛出和处理在main()函数中实现;第二种方法要求抛出异常和处理异常在不同的函数中处理,也就是在一个函数中抛出异常,但是不处理,在调用该函数的上层函数体中捕获并处理该异常。 package two; import java.util.Scanner; class MyException extends Exception { private String myString; public MyException(String myString) { this.myString = myString; } public String getMyString() { return myString; } public String toString() { return myString; } } public class Two1 { public static void main(String[] args) { String str; Scanner sc=new Scanner(System.in); System.out.println(\请输入字符串:\ str=sc.next(); try { for(int i=0;i package Two_2; import java.util.Scanner; class MyException extends Exception { private String myString; public MyException(String myString) { this.myString = myString; } public String getMyString() { return myString; } public String toString() { return myString; } } public class Two_2 { public static void check() throws MyException { String str; Scanner cin=new Scanner(System.in); System.out.println(\请输入字符串:\ str=cin.next(); for(int i=0;i 20.从键盘输入两个数,进行减法运算,当输入的串中包含非数字字符时候,捕获InputMismatchException异常,并进行相应处理。 package three; import java.util.InputMismatchException; import java.util.Scanner; public class SubWrong { public static void main(String[] args) { int a,b; Scanner in=new Scanner(System.in); try { a=in.nextInt(); } catch (InputMismatchException e){ System.out.println(\格式错误!!!\ a=0; } try{ b=in.nextInt(); } catch (InputMismatchException e){ System.out.println(\格式错误!!!\ b=0; } System.out.println(\ } } 21.从键盘输入一个字符串放在一个 String类型的变量中,判断这个字符串的第10个字符是否等于‘R’,并且判断这个字符串的第3个到第7个字符的子串的值是否等于整数2014,如果这两个条件成立,显示“it's ok”,否则显示“the value is wrong”. 如果输入的字符串不足10个字符,则发生系统异常StringIndexOutOfBoundsException,如果第3到7个位置的子串不等于整数2014,则发生系统异常NumberFormatException。做相应的异常处理。 package four; import java.util.Scanner; public class StrWrong { public static void main(String[] args) { Scanner scan=new Scanner(System.in); System.out.println(\请输入一个字符串:\ String str; str=scan.next(); int len=str.length(); try{ if(len<10) throw new StringIndexOutOfBoundsException(\输入字符串不足10字符\ else if(str.indexOf(\ throw new NumberFormatException(\第3到7个字符子串值不等于2014\ else if(str.charAt(9)=='R') System.out.println(\ }catch(StringIndexOutOfBoundsException e) { System.out.println(e.getMessage()+\ }catch(NumberFormatException e) { System.out.println(e.getMessage()+\ } } } 18.实现一个单向链表,链表的每个节点包括整型数据域和下一个节点的引用,要求实现链表的建立(建立的链表必须有序,按数据域升序排列)、节点的插入、节点的删除、链表的遍历(打印)要求首先建立一个名为LinkNode的结点类,其中包括数据成员int data 和 LinkNode next,分别表示结点的数据域和链表中下一个结点的引用。写出该类的构造函数,以及public void DisplayLinkNode()成员函数,打印当前结点的数据域的值。然后再写一个名为 LinkList的链表类,包括数据成员LinkNode head,表示链表的头结点的引用,按下列给出的类的框架完善各个成员函数
正在阅读:
Java历次实验课代码10-06
县督查室2010年工作总结07-07
水浒传竞赛题目-选择题12-04
财务管理概述(无答案(参考Word)05-08
近藤大介:朝鲜的未来之路06-22
京建发【2011】258号附件:北京市建筑业企业违法违规行为记分标准(2011版核稿)07-24
高中教材中出现的物理学史、化学史、生物学史 - 图文03-29
试论鲁迅作品中的妇女形象10-21
电线电缆行业各工种应知应会09-01
- 多层物业服务方案
- (审判实务)习惯法与少数民族地区民间纠纷解决问题(孙 潋)
- 人教版新课标六年级下册语文全册教案
- 词语打卡
- photoshop实习报告
- 钢结构设计原理综合测试2
- 2014年期末练习题
- 高中数学中的逆向思维解题方法探讨
- 名师原创 全国通用2014-2015学年高二寒假作业 政治(一)Word版
- 北航《建筑结构检测鉴定与加固》在线作业三
- XX县卫生监督所工程建设项目可行性研究报告
- 小学四年级观察作文经典评语
- 浅谈110KV变电站电气一次设计-程泉焱(1)
- 安全员考试题库
- 国家电网公司变电运维管理规定(试行)
- 义务教育课程标准稿征求意见提纲
- 教学秘书面试技巧
- 钢结构工程施工组织设计
- 水利工程概论论文
- 09届九年级数学第四次模拟试卷
- 实验课
- 历次
- 代码
- Java