Java实验报告实验4

Java实验报告实验4

课程名称: 面向对象程序设计 实验类型: 设计型

实验项目名称: 综合设计

实验地点: 实验日期: 2021 年 月 日

成绩:

一、实验目的及要求

掌握Java GUI图形用户界面的设计,以及Java事件处理机制,完成数据的输入输出,同时会运用Java中的异常处理机制处理程序中可能出现的异常。

二、实验环境及要求

Jdk1.8以上的开发环境,可使用任何编辑器。

三、实验内容及相应程序

*实验内容:

1、完成图1显示的窗体。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-tzexqzhJ-1654353711852)(file:///C:/Users/陈小贵儿/AppData/Local/Packages/oice_16_974fa576_32c1d314_bd4/AC/Temp/msohtmlclip1/01/clip_image002.jpg)]

图1 学生成绩输入窗体

2、单击“提交”按钮,会将姓名、Java文本框中的内容写入到scores.txt中,写入形式如下:

王明 95

刘小林 75

3、单击“重写”按钮,会清空姓名、Java文本框中的内容。

4、要求必须处理程序中可能出现的所有异常。

相应程序:

package 实验4测试3;

import java.awt.Dimension;
import java.awt.FlowLayout;
import java.awt.Font;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.io.FileOutputStream;
import java.io.IOException;

import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JTextField;

public class Grade {
	 
	//在类中定义主函数
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		//在主函数中,实例化Login类的对象,调用初始化界面的方法
		Grade login = new Grade();
		login.initUI();
 
	}

	private void initUI() {
		// TODO 自动生成的方法存根
		JFrame frame = new JFrame();
		frame.setTitle("学生成绩输入:");
		frame.setSize(400, 250);
		frame.setDefaultCloseOperation(3);
		frame.setLocationRelativeTo(null);
		frame.setResizable(false);
		frame.setFont(new Font("黑体",Font.PLAIN,14));
		FlowLayout fl = new FlowLayout(FlowLayout.CENTER,10,10);
		frame.setLayout(fl);
		
		JLabel labname = new JLabel("姓名:");
		labname.setFont(new Font("黑体",Font.PLAIN,14));
		frame.add(labname);
		JTextField text_name = new JTextField();
		Dimension dim1 = new Dimension(300,30);
		text_name.setPreferredSize(dim1);
		frame.add(text_name);
		
		JLabel java = new JLabel("java:");
		java.setFont(new Font("黑体",Font.PLAIN,14));
		frame.add(java);
		JTextField text_java = new JTextField();
		text_java.setPreferredSize(dim1);
		frame.add(text_java);
		
		JButton button1 = new JButton();	
		Dimension dim2 = new Dimension(100,30);
		button1.setText("提交");
		button1.setFont(new Font("黑体",Font.PLAIN,14));
		button1.setSize(dim2);
		frame.add(button1);
		
		JButton button2 = new JButton();
		button2.setText("重写");
		button2.setFont(new Font("黑体",Font.PLAIN,14));
		button2.setSize(dim2);
		frame.add(button2);
		
		frame.setVisible(true);
		
		button2.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent arg0) {
				text_java.setText("");
				text_name.setText("");
			}
		});
		
		button1.addActionListener(new ActionListener() {
			public void actionPerformed(ActionEvent e) {
				String str1=text_name.getText();
				String str2=text_java.getText();
				text_name.setText(str1);
				text_java.setText(str2);
					try{
						FileOutputStream out = new FileOutputStream("scores.txt");
						byte[] ch1 = str1.getBytes();
						byte[] ch2 = "\r\n".getBytes();
						byte[] ch3=str2.getBytes();
							out.write(ch1);
							out.write(ch2);
							out.write(ch3);
							out.close();
						}
						
					catch(IOException we){
						System.out.println("Error"+e);
					}
			}
		});
	}
}

//copyright by axuan1226

四、实验结果

在这里插入图片描述

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-xf0qbZS0-1654353711855)(C:\Users\陈小贵儿\AppData\Roaming\Typora\typora-user-images\image-20220604223205882.png)]

五、分析与讨论(实验过程中发现的重点与难点)

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实验目的: 通过本实验,实现对堆排序算法的理解,掌握堆排序算法的原理以及实现方法,并掌握Java语言的编程技巧。 实验内容: 堆排序是一种树形选择排序方法,是对直接选择排序算法的有效改进。堆排序的基本思想是:将待排序的序列构造成一个大根堆或小根堆,堆顶元素为最大值或最小值,然后将堆顶元素与最后一个元素交换,然后把剩余的元素重新构造成堆。如此反复执行,直到排序完成。由于堆排序算法的时间复杂度为O(nlogn),因此在大数据量的情况下,堆排序是高效的。 堆排序算法的实现主要有两个步骤:构建初始堆和堆排序。其,构建初始堆是将待排序的序列构建成一个大根堆或小根堆的过程,堆排序是不断将堆顶元素与最后一个元素交换,并重新调整堆的过程。 以下是Java语言实现堆排序的代码: ```java public class HeapSort { public static void heapSort(int[] arr) { int n = arr.length; // 构建初始堆 for (int i = n / 2 - 1; i >= 0; i--) heapify(arr, n, i); // 堆排序 for (int i = n - 1; i >= 0; i--) { // 将堆顶元素与最后一个元素交换 int temp = arr[0]; arr[0] = arr[i]; arr[i] = temp; // 调整堆 heapify(arr, i, 0); } } // 调整堆 public static void heapify(int[] arr, int n, int i) { int largest = i; int left = 2 * i + 1; int right = 2 * i + 2; // 找到左子节点和右子节点的最大值 if (left < n && arr[left] > arr[largest]) largest = left; if (right < n && arr[right] > arr[largest]) largest = right; // 如果最大值不是根节点,则交换根节点和最大值,并递归调整子堆 if (largest != i) { int temp = arr[i]; arr[i] = arr[largest]; arr[largest] = temp; heapify(arr, n, largest); } } public static void main(String[] args) { int[] arr = { 64, 34, 25, 12, 22, 11, 90 }; heapSort(arr); System.out.println("排序后的数组:"); for (int i = 0; i < arr.length; i++) System.out.print(arr[i] + " "); } } ``` 实验结果: 经过测试,以上代码能够正确地对数列进行堆排序,得到正确的排序结果。 实验总结: 通过本次实验,我学习了堆排序算法的原理和实现方法,并通过Java语言编写了相应的代码。堆排序算法具有高效的时间复杂度,在大数据量的情况下具有明显的优势。这次实验让我对Java语言的编程技巧有了更深刻的理解,也对算法的实现有了更深的认识。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值