数据结构课程实验一 JAVA程序设计基础

2020-05-24 10:47

实验报告一 JAVA程序设计基础及算法设计

班级________ 学号______ 姓名_____ 专业_____ 一、 实验目的:

(1) 掌握JAVA语言的语法,理解数组和对象的引用模型,理解类的封装、继承和多态 (2) 掌握类的设计方法

(3) 掌握异常处理方法和标准输出方法,了解标准输入方法 (4) 熟悉算法的描述方法、算法时间复杂度的分析和计算方法 (5) 理解数据和算法的基本概念 二、 实验内容:

1、 采用二维数据输出杨辉三角形,二维数据的结构如图1所示:

0 1 2 3 4 5 mat mat[0] 1 mat[1] 1 1 mat[2] 1 2 1 mat[3] 1 3 3 1 mat[4] 1 4 6 4 1 mat[5] 1 5 10 10 5 1

图1 杨辉三角形的二维数组结构

请粘贴源程序及运行测试结果: 源程序:

import java.util.Scanner;

public class Ex {

public static void pri( int a[][], int x){ }

public static int[][] Def(int x){ }

public static void main(String[] args){

Scanner scan=new Scanner(System.in); int a[][]=new int[x][x]; for(int i=0;i

for(int i=2;i

for(int j=1;j

a[i][j]=a[i-1][j]+a[i-1][j-1]; a[i][0]=1; a[i][i]=1; for(int i=0;i

for(int j=0;j<=i;j++){ }

System.out.println();

System.out.printf(\ ,a[i][j]);

}

}

System.out.println(\输入维数:\); int x=scan.nextInt(); int a[][]=Def(x); scan.close(); pri(a,x);

运行结果:

2、 找出一个二维数据的鞍点,即该位置上的元素在该行上最大,在该列中最小。一个二维

数组可能没有鞍点,如果有,那么它只有一个鞍点。

请粘贴源程序及运行测试结果:

public class EX1 {

public static int[][] Def(int a, int b){ }

public static int Find(int[][] x){

int min=0,max=0,a=0;

for(int i=0;i

max=0;

for(int j=0;j

if(max

max=x[i][j]; a=j;

int x[][]=new int[a][b]; for(int i=0;i

return x;

for(int j=0;j

System.out.println(\);

x[i][j]=(int)(10*Math.random()); System.out.printf(\, x[i][j]);

}

}

}

}

}

if(min>x[i][a]){ }

min=x[i][a];

for(int z=0;z

if(max==min) }

return max;

return 0;

public static void main(String[] args) { }

int x[][]=new int[6][6]; int a=0; x=Def(5,5); a=Find(x); if(a!=0){ } else{ }

System.out.printf(\此数组没有鞍点\); System.out.printf(\此数组鞍点为+M\,a);

结果:

3、 设计复数类,成员变量包括实部和虚部,成员方法包括实现复数加法、减法、比较、转

换成字符串等运算或操作。

[测试数据]

(1)Z1=0,Z2=0; (2)Z1=4,Z2=3i;

(3)Z1=3+1.5i,Z2=8-1.5i; (4)Z1=-4+3.4i,Z2=-6-8.1i; (5)Z1=-5.4+1.2i,Z2=5.4+3.2i; (6)Z1的共轭复数:

private double realPart; private double imaginPart; public complex(){ }

public complex(double a, double b){ }

public double getrealPart(){ }

public void setrealPart(double a){ }

public double getimaginPart(){ }

public void setimaginPart(double b){ }

public complex complexAdd(complex c){ }

public complex complexMinus(complex c){ }

public complex complexG(complex c){

complex x=new complex();

double a=(double)this.imaginPart; complex x=new complex();

x.realPart=this.realPart-c.realPart; x.imaginPart=this.imaginPart-c.imaginPart; return x;

complex x=new complex();

x.realPart=this.realPart+c.realPart; x.imaginPart=this.imaginPart+c.imaginPart; return x;

this.imaginPart=b; return imaginPart; this.realPart=a; return realPart; this.realPart=a; this.imaginPart=b; realPart=0; imaginPart=0;

public class complex {

}

}

x.realPart=this.realPart; x.imaginPart=a*-1; return x;

public String toString(){ }

return realPart+\+imaginPart+\;

import java.util.Scanner;

public class Test {

static double x1=0; static double y1=0; static double x2=0; static double y2=0;

static Scanner scan=new Scanner(System.in); static complex z1=new complex(); static complex z2=new complex(); public static void Def(){ }

public static void Pri(){

System.out.println(\+z1.toString()); System.out.println(\+z2.toString());

System.out.println((\+z1.complexAdd(z2)).toString()); System.out.println((\+z1.complexMinus(z2)).toString()); System.out.println(\输入Z1的实部:\); x1=scan.nextDouble();

System.out.println(\输入Z1的虚部:\); y1=scan.nextDouble();

System.out.println(\输入Z2的实部:\); x2=scan.nextDouble();

System.out.println(\输入Z2的虚部:\); y2=scan.nextDouble(); z1.setrealPart(x1); z1.setimaginPart(y1); z2.setrealPart(x2); z2.setimaginPart(y2);


数据结构课程实验一 JAVA程序设计基础.doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:ABB机器人编程程序解析

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: