1.Github项目地址:

https://github.com/ataiyang/ls

2.PSP表格

PSP2.1 Personal Software Process Stages 预估耗时(分钟) 实际耗时(分钟)
Planning 计划
· Estimate · 估计这个任务需要多少时间 2880 1440
Development 开发
· Analysis · 需求分析 (包括学习新技术) 120 60
· Design Spec · 生成设计文档 30 15
· Design Review · 设计复审 (和同事审核设计文档) 60 60
· Coding Standard · 代码规范 (为目前的开发制定合适的规范) 60 60
· Design · 具体设计 60 60
· Coding · 具体编码 180 150
· Code Review · 代码复审 60 45
· Test · 测试(自我测试,修改代码,提交修改) 120 60
Reporting 报告
· Test Report · 测试报告 60 60
· Size Measurement · 计算工作量 30 30
· Postmortem & Process Improvement Plan · 事后总结, 并提出过程改进计划 30 30
合计 3690 2070

3.解题思路

刚刚拿到题目时一脸懵逼,后来上网查了相关资料了后,发现了一种随机的方式,网上那个是解数独的方法,我将它改装了一下,大致思路是这样的:按顺序一个个随机,当每个随机时去判断每行每列及所在宫里是否有相同的数,如果有,该位置重新随机,并记录次数,当重新随机次数超过50时,从头开始随机,如果没有,随机下一个位置的数,如果填满了九宫格,则算一次成功,输出。(为什么是50,因为刚开始时是10,时间太长了2.5分钟,改成20,时间20几秒,改成30,时间18秒,40时间15秒,50时间13~14秒)。

遇到的困难及学习的新知识

时间上有点久后来记录错误的参数变大,就解决了。

命令行传参原本不会,百度去了解后会了。

输出到文件也是原本不会,后也去百度了解解决了。

4.设计实现

没有类,2个函数,一个函数用来完成填一个九宫格的过程,一个函数用来实现判断是否符合数独的规律,后来将第一个函数移到主函数中了。

5.代码说明

这是判断的主要代码:

	for (m = 0, n = j; m < 9; m++) {//判断行里是否有重复的数
if (a[m][n] == a[i][j] && m != i) {
return 0;
}
}
for (m = i, n = 0; n < 9; n++) {//判断列里是否有重复的数
if (a[m][n] == a[i][j] && n != j) {
return 0;
}
}
p = i / 3;
q = j / 3;
for (m = p * 3, n = q * 3; m < (p + 1) * 3;) {//判断本宫里是否有重复的数
if (a[m][n] == a[i][j] && m != i&&n != j) {
return 0;
}
else {
if (n < (q * 3 + 2)) {
n++;
}
else {
n = q * 3;
m++;
}
}
}

这是填空的主要代码:

	for (l = 0; l < n; l++) {
int a[9][9] = { 0 };//九宫格初始化
int i, j, m, n, x, k = 0;
for (i = 0, j = 0; i != 9;) {
if (i == 0 && j == 0) {//学号后2位为23,所以是6
a[i][j] = 6;
k = 1;
}
if (k == 0) {
a[i][j] = rand() % 9 + 1;//填当前格
}
if (judge(a, i, j)) {
if (j < 8) {
j++;
k = 0;
}
else {
i++;
j = 0;
k = 0;
}
}
else if (k<50) {//k用来记录当前格错误次数,当超过50个时,从头开始
k++;
a[i][j] = rand() % 9 + 1;
}
else if (k == 50) {
k = 0;
for (i = 0, j = 0; i < 9;) {//重新初始化
a[i][j] = 0;
if (j < 8) { j++; }
else {
j = 0;
i++;
}
}
i = 0;
j = 0;
}
}

6.测试运行

这是运行结果的部分截图:

7.性能分析

这是性能分析的截图:

8.学习进度条

第N周 新增代码(行) 累计代码(行) 本周学习耗时(小时) 累计学习耗时(小时) 重要成长
1 120 120 24 24 学会很多小技巧,命令行传参,输出到文件之类

9.执行力 、 泛泛而谈 的理解

我认为,执行力就是实际去做事情,将想法付诸行动实现的能力,而泛泛而谈就是说个大概,列举出很多在做之前的想法为了将来做事情做准备,两者都是有用的,大概就是这样了。

sudoku作业的更多相关文章

  1. 第二次作业——个人项目实战(Sudoku)

    Github:Sudoku 项目相关要求 利用程序随机构造出N个已解答的数独棋盘 . 输入 数独棋盘题目个数N 输出 随机生成N个 不重复 的 已解答完毕的 数独棋盘,并输出到sudoku.txt中, ...

  2. 17秋 软件工程 第二次作业 sudoku

    2017年秋季 软件工程 作业2:个人项目 sudoku Github Project Github Project at Wasdns/sudoku. PSP Table PSP2.1 Person ...

  3. 软工实践作业2:个人项目实战之Sudoku

    Github:Sudoku 项目相关要求 项目需求 利用程序随机构造出N个已解答的数独棋盘 . 输入 数独棋盘题目个数N(0<N<=1000000). 输出 随机生成N个不重复的已解答完毕 ...

  4. Sudoku(第二次作业)

    这里是github 工具清单: 编程语言:C++ 编程IDE:XCode 效能分析工具:XCode 源代码管理平台:Github PSP2.1 PSP2.1 Personal Software Pro ...

  5. 软工实践第二次作业-sudoku

    说明 Github项目地址 作业题目 解题思路 一开始拿到的时候,有一个思路,可以先填写全盘的"1",然后在插空填满全盘的"2".后来觉得自己理不清那个思路.遂 ...

  6. 第二次作业——个人项目实战(sudoku)

    第二次作业--个人项目实战(sudoku) 一.作业要求地址 第二次作业--个人项目实战 二.Github项目地址 softengineering1--sudoku 三.PSP表格估计耗时 PSP2. ...

  7. 【2019.09.19】数独(Sudoku)游戏之我见(软工实践第三次作业)

    Github项目地址:https://github.com/MokouTyan/suduku_131700101 [2019.09.20]更新:代码经过Code Quality Analysis工具的 ...

  8. ACM: ICPC/CCPC Sudoku DFS - 数独

    Sudoku Time Limit : 3000/1000ms (Java/Other)   Memory Limit : 65535/65535K (Java/Other) Total Submis ...

  9. sudoku--SE第二次作业

    git传送门 编译环境: windows10.vs2017 所用语言: c++ 首先作为一个晚上闭眼的玩家,我先来讲一下我的心路历程: 最开始接到作业的时候心里是拒绝的,刚出了一趟小远门就这样,就很难 ...

随机推荐

  1. 如何开发自己的搜索帝国之安装ik分词器

     Elasticsearch默认提供的分词器,会把每个汉字分开,而不是我们想要的根据关键词来分词,我是中国人 不能简单的分成一个个字,我们更希望 “中国人”,“中国”,“我”这样的分词,这样我们就需要 ...

  2. 白话ASP.NET MVC之三:Controller是如何解析出来的

    我们在上一篇文章中介绍Controller激活系统中所涉及到的一些类型,比如有关Controller类型的相关定义类型就包括了IController类型,IAsyncController类型,Cont ...

  3. windows域与工作组概念

    局域网上的资源需要管理,“域”和“工作组”就是两种不同的网络资源管理模式.那么二者有何区别呢? 工作组 Work Group 在一个网络内,可能有成百上千台电脑,如果这些电脑不进行分组,都列在“网上邻 ...

  4. 连上Wi-Fi 热点自动弹窗的实现方法

    当我们连上某个热点, 自动弹出登录窗口的专业名称叫做: Captive portal 原理, 实现方式有三种 1 : dns 跳转, 在热点上面实现配置, 把所有dns请求返回都配置为:服务器地址 : ...

  5. 为什么eclipse修改程序之后运行的时候还是前一版本的内容?

    问题:我用的是Eclipse Java Neon4.6.0,同样的这个问题也出现在其他的Eclipse的版本上,我在对我的代码内容进行修改的时候,点击运行,发现还是执行的修改之前的文件,这让我很头疼. ...

  6. MarkdownPad2的密钥

    MarkdownPad2的密钥 经本人试用 邮箱: Soar360@live.com 授权秘钥: GBPduHjWfJU1mZqcPM3BikjYKF6xKhlKIys3i1MU2eJHqWGImDH ...

  7. 常用的Linux发行版

    Linux发行版百花齐放 [内容摘要] 如今,众多的Linux发行版百花齐放,linux的阵营日益壮大,每一款发行版都拥有一大批用户,开发者自愿为相关项目投入精力.Linux发行版可谓是形形色色,它们 ...

  8. Class类 获取Class对象

    阅读API的Class类得知,Class 没有公共构造方法.Class 对象是在加载类时由 Java 虚拟机以及通过调用类加载器中的 defineClass 方法自动构造的 获取Class对象的三种方 ...

  9. python-opencv在有噪音的情况下提取图像的轮廓

    对于一般的图像提取轮廓,这篇博文介绍了一个很好的方法,但是对于有噪声的图像,并不能很好地捕获到目标物体. 比如对于我的鼠标,提取的轮廓效果并不好,因为噪声很多: 所以本文增加了去掉噪声的部分. 首先加 ...

  10. 面试的妹纸问我:web缓存设置不是后台的事情吗?

    背景介绍 团队最近在招前端开发,早上收到一封简历,是个妹纸,从技能点来看还算符合要求,于是约了下午3点过来面试. 整个面试过程持续了大约40分钟,问的题目也比较常规,其中一道题就是"常见的性 ...