软工实践_Task2

标签(空格分隔): 软工实践


相关要求第二次作业——个人项目实战

github传送门


解题思路

  • 先是一点杂谈。

  • 首先,看完作业要求之后,心里先有个大概的框架。

    • 语言:C++
    • IDE:本机已安装Visual Studio 2015
    • 效能分析工具:Visual Studio Profiling Tools?善用搜索引擎,下一个。
    • 项目需求:很直观的想法是,一共\(9*9\)个位置,每个位置都随意的填上一个可满足的数,最后形成九宫格。
    • 注意:命令行输入,文件输出,输出格式,\(0<N<=1000000\),左上角的第一个数有特殊要求
    • github:文件组织框架
    • PSP:小说.push(《构建之法》)
    • 暂不考虑附加题
  • 再次细看博客之后,发现一些注意点:

    • 生成的棋盘不重复

      • 一种想法是每生成一个棋盘之后都check一下这个棋盘是否生成过,但是考虑到输入的N的范围,显然这么做过于耗费时间。
      • 换一个路子,既然不能每次都\(check\),那么就得让每次填数的随机性要足够的高。
    • 测试数据中有可能出现错误
      • 注意特殊处理。
    • 使用单元测试对项目进行测试,并使用插件查看测试分支覆盖率等指标。
    • 代码有进展即签入Github
    • 性能分析图,VS 2015的性能分析工具可自动生成。
  • 这样,大概就有个思路,要去怎么实现。结合上述的注意点,考虑到时间、随机性问题,一开始的直观的想法显然需要改进。

  • 考虑第一行,他肯定是一个1到9的排列。

  • 考虑到每个位置只有9种选择,所以每次都rand是不需要的,只要每次从1到9一个个试,check能否填。

  • 考虑到这样子随机性可能不是太好,所以可以再改进一下,每次不必按1到9的顺序去试数,而是将这个试数的序列也随机化,这样子能改善随机性。


设计实现

  • class

    • Sudoku类:

      • 构造、析构函数
      • void SudokuGenerate(); 【publish,生成一个数独】
      • void SudokuPrint(); 【publish,输出一个数独】
      • void getNext(int &i, int &j); 【private,得到下一个位置】
      • bool judge(int row, int col, int curnum); 【private,判断(row, col)这个位置放curnum是否合理】
      • bool dfs(int i, int j); 【private,递归填数】
      • void Generate(); 【private,生成数独】
      • void print(); 【private,输出数独】
  • bool digitCheck(char *s) 【判断当前是否是一个整数】
  • int main(int argc, char *argv[])
    • 从命令行获取输入,调用digitCheck函数判断该输入是否合法。
    • 若输入不合法,输出提示信息。
    • 否则,实例化Sudoku类,调用SudokuGenerate生成一个数独,调用SudokuPrint输出这个数独

代码说明

  • bool Sudoku::judge(int row, int col, int curnum);

    • 判断(row, col)这个位置放curnum是否合理,判断方法为,当前行/当前列/当前块是否已经填过curnum这个数
bool Sudoku::judge(int row, int col, int curnum)
{
// check the col
rep(i, 0, row)
if (sudoku[i][col] == curnum) return false;
// check the row
rep(j, 0, col)
if (sudoku[row][j] == curnum) return false;
// check the area
int belongRow = row / 3 * 3;
int belongCol = col / 3 * 3; // get the upleft of the area
int index = (row % 3) * 3 + (col % 3);
while (--index >= 0)
{
if (sudoku[belongRow + index / 3][belongCol + index % 3] == curnum) return false;
}
return true;
}
  • bool Sudoku::dfs(int i, int j)

    • 递归填数,当(i, j)位置可以填某个数,且填该数可以得到解时,填这个数。
bool Sudoku::dfs(int i, int j)
{
if (i == 9) return true;
for (auto &curnum : trynum)
{
if (judge(i, j, curnum))
{
sudoku[i][j] = curnum;
int _i = i;
int _j = j;
getNext(_i, _j);
if (dfs(_i, _j)) return true;
sudoku[i][j] = 0;
}
}
return false;
}

测试运行


性能测试

上图的运行参数为【sudoku.exe -c 100000】,可以看到,总执行时间为57.4s,其中SudokuGenerate和SudokuPrint占了较大的比重。


题外话

  • 很绝望啊喂,一回到学校,笔记本就进水GG,项目也还没传github,最后还是在实验室配了半天的VS外加借舍友电脑,匆匆忙忙的写完了基本的作业需求。

软件工程实践_Task2_sudoku的更多相关文章

  1. 关于Axure RP软件的介绍——软件工程实践第二次个人作业

    关于Axure RP软件的介绍——软件工程实践第二次个人作业 Axure RP是一个非常专业的快速原型设计的一个工具,客户提出需求,然后根据需求定义和规格.设计功能和界面的专家能够快速创建应用软件或W ...

  2. 福州大学软件工程1816 | W班 第10次作业[软件工程实践总结]

    作业链接 个人作业--软件工程实践总结 评分细则 本次由五个问题(每个十分)+创意照片(五分)+附加题(十分)组成 评分统计图 千帆竞发图 汇总成绩排名链接 汇总链接

  3. 个人作业——软件工程实践总结&个人技术博客

    一. 回望 (1)对比开篇博客你对课程目标和期待,"希望通过实践锻炼,增强软件工程专业的能力和就业竞争力",对比目前的所学所练所得,在哪些方面达到了你的期待和目标,哪些方面还存在哪 ...

  4. 【The final】软件工程实践总结

    软件工程就这么告一段落了,竟然有那么一丢丢的舍不得-- 一.为拖延找的种种借口     [首先声明]以下纯粹是个人吐槽,仅作记录以便日后自己可以回顾一下往昔罢了,可以直接忽略,跳到第二大点:我的拖延之 ...

  5. 软件工程实践助教每周小结 < 福州大学 | 傅明建 >

    第一周助教小结 1. 助教博客链接: http://www.cnblogs.com/sinceway/ 2. 本周点评的作业数量:约22份,有多次交互 3. 本周点评有困难的作业链接: https:/ ...

  6. 软件工程实践一 —— java之wc.exe

    SoftwareEngineering-wc github项目地址:https://github.com/CuiLam/SoftwareEngineering-wc   项目相关要求 实现一个统计程序 ...

  7. 【软件工程实践一】git使用心得

    第一次软工实践,我们需要做的是学习如何使用github,并将本地库的文件添加到远程库中,以下是我进行实践的工程. [一.git的安装及准备工作] 首先从http://msysgit.github.io ...

  8. 软件工程实践-WC项目之C实现

    1.Github项目地址 https://github.com/ShadowEvan/homework 基本功能 -c 统计文件字符数(实现) -w 统计文件词数(实现) -l  统计文件行数(实现) ...

  9. [福大软工] Z班 软件工程实践总结 作业成绩

    作业要求 http://www.cnblogs.com/easteast/p/8081265.html 评分细则 本次作业评分满分为20分,分为五个部分,分别如下: 回望过去(5'):以实际数据总结分 ...

随机推荐

  1. redis.properties

    #### env:${env} redis.maxIdle= ##最小空闲数 redis.minIdle= ##最大连接数:能够同时建立的“最大链接个数” redis.maxTotal= #每次最大连 ...

  2. win32进程概念之句柄表,以及内核对象.

    句柄表跟内核对象 一丶什么是句柄表什么是内核对象. 1.句柄表的生成 我们知道.我们使用CreateProcess 的时候会返回一个进程句柄.以及线程句柄. 其实在调用CreateProcess的时候 ...

  3. PetaPoco在ASP.NET Core 2.2中使用注入方式访问数据库

    .Net Core中一个特别重要的特性就是依赖注入功能,那么我们在使用PetaPoco的时候是否也可以使用依赖注入特性呢? 回答当然是可以的啦.使用方法(两种注入方式)如下 services.AddS ...

  4. 只知道ajax?你已经out了

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由前端林子发表于云+社区专栏 随着前端技术的发展,请求服务器数据的方法早已不局限于ajax.jQuery的ajax方法.各种js库已如雨 ...

  5. 精读JavaScript模式(四),数组,对象与函数的几种创建方式

    一.前言 放了个元旦,休息了三天,加上春运抢票一系列事情的冲击,我感觉我的心已经飞了.确实应该收收心,之前计划的学习任务也严重脱节了:我恨不得打死我自己. 在上篇博客中,笔记记录到了关于构造函数方面的 ...

  6. Spring @RequestAttribute

    @RequestAttribute注解用法 @RequestAttribute用在方法入参上,作用:从request中取对应的值,至于request中是怎么存在该属性的,方式多种多样,拦截器中预存.M ...

  7. Angular2入门:TypeScript的类型 - 对象解构

  8. c#连接访问数据库(菜鸡篇)

    C#如何访问数据库(小白篇) 刚入坑不久学习的路上还是遇到了不小的问题,昨天学习C#的时候需要连接数据库获取数据. 网上有很多这样的文章,说实话对于我这样的小白还真是有点难理解,经过一番周折总算是了解 ...

  9. 使用 Immutable Subject 来驱动 Angular 应用

    现状 最近在重构手上的一个 Angular 项目,之前是用的自己写的一个仿 Elm 架构的库来进行的状态管理,期间遇到了这些痛点: 样板代码太多 异步处理太过繁琐 需要单独维护一个 npm 包 其中, ...

  10. 【github&&git】6、SmartGit(试用期30后),个人继续使用的方法。

    在我们做项目的过程中,我们会用到SmartGit这个软件来将本地的MAVEN项目push到国内的码云(https://git.oschina.net)或者是国外的github网站进行项目的管理,这个时 ...