软件构造lab1心得与体会

2023-11-23 06:30
文章标签 软件 构造 心得 体会 lab1

本文主要是介绍软件构造lab1心得与体会,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

0x00 序

上一次接触java还是一年前写Android程序的时候,虽说写了不少代码其实本身对java并不熟悉,借此次Lab1的机会也正好学学java。

0x01 Magic Squares (MIT)

  1. 文件读入

有很多种方法,本此实验用到了以下方法

FileReader in = new FileReader(fileName);
BufferedReader br = new BufferedReader(in);
String oneLine;
// read by line
while((oneLine = br.readLine()) != null){...
}
  1. 文件读出
File file = new File("src/P1/6.txt");
// if file doesnt exists, then create it
if (!file.exists()) {file.createNewFile();}
FileWriter fw = new FileWriter(file.getAbsoluteFile());
BufferedWriter bw = new BufferedWriter(fw);
// write 
bw.write(...);
bw.close();

需要注意参数fileName(字符串)和file(文件)的区别

  1. 其他函数

用法类似,一触即通(split也太香了

//Integer ---> string / ...
Integer.toString(...) //check if is digit / ...
Character.isDigit(...) // Sring.split
String oneLine;
// split by ...
String[] word = oneLine.split(...);
  1. 数组
// 静态
int[] m = new int[len]
int[][] matrix = new int[wid][len];// 动态
int []arr
int [][] matrix ;  // 动态创建
arr = new int[len];
matrix = new int [wid][];     
for ( i = 0 ; i < wid ; i++ ) {  matrix [i] = new int [len];      }// ArrayList
ArrayList list = new ArrayList(); 
for( int i=0;i <10;i++ ) list.Add(i);

与c语言不同,java的数组全部存放在堆(?)上,堆内存映射二进制0,这也解释了为什么数组数据一开始都是0。

  1. 异常处理

不太理解任务2为什么会自动抛出n不是奇数的异常(代码中并没有异常处理)。
如果是自动触发的为什么读写file的时候得try catch指出IOException…

0x02 TurtleSoup

这题配置环境给我恶心坏了,同时由于周围同学基本上都用eclipse,idea新手用户表示一切都要自己摸索。但当我欣赏着idea舒适的界面与强大的功能时,我明白了我的选择没有错。

  1. 找不到程序包

由于敝校在MIT的程序任务中多加了一层路径P2导致文件全部冒红,将冒红处添上P2.即可,如将下图地址修改为P2.turtle.Action.ActionType
在这里插入图片描述

  1. junit报错

须手动添加junit包
Ans1.直接在File->Project Structure->library->Java中找到idea安装位置下lib文件里的junit-4.12.jar并添加(但助教好像说这样他没发批改)

Ans2.也可以将junit-4.12.jar复制出来,建立lib文件夹并放进去,右键->add to library即可。

同时由于junit-4.11以后不再包含hamcrest包,也得把这个包添加进来。完成后可以在.iml文件中看到下图改变:
在这里插入图片描述
然后就可以使用junit了,同时可以看到idea在一个project中运行多个test\main()是多么方便,即可以run也可以debug。
在这里插入图片描述

  1. calculateBearingToPoint()

统一标准为计算顺时针转过的角度(0-360°),其中用到Math.atan2()函数,可以在此网站中测试。

public static double calculateBearingToPoint(double currentBearing, int currentX, int currentY,int targetX, int targetY) {if (currentX == targetX && currentY == targetY)return 0;double targetBearing = Math.atan2(targetX - currentX, targetY - currentY) / Math.PI * 180.00;double result = targetBearing-currentBearing;return result>=0 ? result : result+360;}
  1. 凸包问题

有了calculateBearingToPoint()解决方法就很自然能想到:
①取最左边的点(最左边点有不止一个就取他们中最下面的)
②不断找到顺时针旋转最大的点加入到result中,直至找到了最初的点
如此便构成了一个凸包。

Set元素是无序的,遍历可以有两种方法:

// for 
Set<Point> points;
for(Point p:points)
{p....
}//iterator
Iterator<Point> it = points.iterator();
while(it.hasNext())
{Point p = it.next();p....
}

但笔者能力有限,如何避免一条直线上中间的点不会被加入闭包的问题还没有得到完美解决。

  1. PersonalArt

只要改变步长,并每次旋转一个角度就能产生舒适的图形
在这里插入图片描述

0x03 Social Network

  1. 有向图存储

如果不需要存储其他信息,可以如下存储点和边:

//点为Person,即一个个体
Person p1;
//边为Friends,为人的集合
Set<Person> friends;
  1. 类的属性、方法分配

Person类

public class Person {public String name;public boolean isVisit;    // whether is visitedSet<Person> friends = new HashSet<Person>();public Person(String name){this.name = name;}public void makeFriends(Person p){friends.add(p);}
}

FriendshipGraph类


public Set<Person> people = new HashSet<Person>();
private boolean findFlag;
public void addVertex(Person p){...}
public void addEdge(Person p1,Person p2){...}
public int getDistance(Person p1,Person p2){...}
  1. DFS求最短路径

通过递归实现,比较基础的内容但不够熟练

  1. 不足

测试用例不太会构造,Junit也不是很会写,希望后续可以学到。

这篇关于软件构造lab1心得与体会的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/416020

相关文章

软件设计师备考——计算机系统

学习内容源自「软件设计师」 上午题 #1 计算机系统_哔哩哔哩_bilibili 目录 1.1.1 计算机系统硬件基本组成 1.1.2 中央处理单元 1.CPU 的功能 1)运算器 2)控制器 RISC && CISC 流水线控制 存储器  Cache 中断 输入输出IO控制方式 程序查询方式 中断驱动方式 直接存储器方式(DMA)  ​编辑 总线 ​编辑

【STM32】SPI通信-软件与硬件读写SPI

SPI通信-软件与硬件读写SPI 软件SPI一、SPI通信协议1、SPI通信2、硬件电路3、移位示意图4、SPI时序基本单元(1)开始通信和结束通信(2)模式0---用的最多(3)模式1(4)模式2(5)模式3 5、SPI时序(1)写使能(2)指定地址写(3)指定地址读 二、W25Q64模块介绍1、W25Q64简介2、硬件电路3、W25Q64框图4、Flash操作注意事项软件SPI读写W2

免费也能高质量!2024年免费录屏软件深度对比评测

我公司因为客户覆盖面广的原因经常会开远程会议,有时候说的内容比较广需要引用多份的数据,我记录起来有一定难度,所以一般都用录屏工具来记录会议内容。这次我们来一起探索有什么免费录屏工具可以提高我们的工作效率吧。 1.福晰录屏大师 链接直达:https://www.foxitsoftware.cn/REC/  录屏软件录屏功能就是本职,这款录屏工具在录屏模式上提供了多种选项,可以选择屏幕录制、窗口

leetcode105 从前序与中序遍历序列构造二叉树

根据一棵树的前序遍历与中序遍历构造二叉树。 注意: 你可以假设树中没有重复的元素。 例如,给出 前序遍历 preorder = [3,9,20,15,7]中序遍历 inorder = [9,3,15,20,7] 返回如下的二叉树: 3/ \9 20/ \15 7   class Solution {public TreeNode buildTree(int[] pr

HomeBank:开源免费的个人财务管理软件

在个人财务管理领域,找到一个既免费又开源的解决方案并非易事。HomeBank&nbsp;正是这样一个项目,它不仅提供了强大的功能,还拥有一个活跃的社区,不断推动其发展和完善。 开源免费:HomeBank 是一个完全开源的项目,用户可以自由地使用、修改和分发。用户友好的界面:提供直观的图形用户界面,使得非技术用户也能轻松上手。数据导入支持:支持从 Quicken、Microsoft Money

PDF 软件如何帮助您编辑、转换和保护文件。

如何找到最好的 PDF 编辑器。 无论您是在为您的企业寻找更高效的 PDF 解决方案,还是尝试组织和编辑主文档,PDF 编辑器都可以在一个地方提供您需要的所有工具。市面上有很多 PDF 编辑器 — 在决定哪个最适合您时,请考虑这些因素。 1. 确定您的 PDF 文档软件需求。 不同的 PDF 文档软件程序可以具有不同的功能,因此在决定哪个是最适合您的 PDF 软件之前,请花点时间评估您的

springboot体会BIO(阻塞式IO)

使用springboot体会阻塞式IO 大致的思路为: 创建一个socket服务端,监听socket通道,并打印出socket通道中的内容。 创建两个socket客户端,向socket服务端写入消息。 1.创建服务端 public class RedisServer {public static void main(String[] args) throws IOException {

梳理2024年,螺丝钉们爱用的3款剪辑软件

这年头,视频到处都是,就跟天上的星星一样数不清。不管你是公司里的新面孔,还是职场上的老狐狸,学会怎么剪视频,就好比找到了赢的秘诀。不管是给上司汇报工作,展示你的产品,还是自己搞点小视频记录生活,只要是剪辑得漂亮,肯定能一下子吸引大家的目光,让人记得你。咱们今天就来侃侃现在超火的三款视频剪辑工具,尤其是PR剪辑,你肯定听说过,这货在剪辑界可是大名鼎鼎,用它剪视频,既专业又麻利。 NO1. 福昕轻松

秒变高手:玩转CentOS 7软件更换的方法大全

在 CentOS 7 中更换软件源可以通过以下步骤完成。更换源可以加快软件包的下载速度,特别是当默认源速度较慢时。以下是详细步骤: 前言 为了帮助您解决在使用CentOS 7安装不了软件速度慢的问题,我们推出了这份由浪浪云赞助的教程——“CentOS7如何更换软件源加快下载速度”。 浪浪云,以他们卓越的弹性计算、云存储和网络服务受到广泛好评,他们的支持和帮助使得我们可以将最前沿的技术知识分

excel翻译软件有哪些?如何高效提翻译?

你是否曾在面对满屏的英文Excel表格时感到头疼?项目报告、数据分析、财务报表... 当这些重要的信息被语言壁垒阻挡时,效率和理解度都会大打折扣。别担心,只需3分钟,我将带你轻松解锁excel翻译成中文的秘籍。 无论是职场新人还是老手,这一技巧都将是你的得力助手,让你在信息的海洋中畅游无阻。 方法一:使用同声传译王软件 同声传译王是一款专业的翻译软件,它支持多种语言翻译,可以excel