work4
任务概述
给出多条英文单词,找出一个包含所有单词的填字阵。并且对于该方阵有一定特殊要求:
a) Stage 1
- Every phrase in the input file is covered once and only once.
- No less than 2 of the phrases must be in these directions:
- i. top-down, bottom-up, left-right, right-left, and all 4 diagonal directions.
- The width and height of the matrix can be different
- there doesn’t exist a row or column of letters where none of the letters are covered (不存在一行或一列字母不被任何短语覆盖)。
b) Stage 2
- The matrix must have the same width and height
c) Stage 3
- The four corners of the output matrix must be occupied by a phrase.
分析过程
在一开始,基于对要求找到最小方阵的误解。我们很容易想到,如果n*n的方阵能放下这些单词,那么(n+1)*(n+1)的方阵则一定能放下。而且严格要求方阵是正方形,所以一开始我想的方案是二分k的大小,然后看k*k的正方形矩阵是否能放入这些单词。
然而,判断过程非常复杂,而且时间复杂度不可估计,所以我放弃了这个想法。
退而求其次,我们可以先找到一个较优解。然后在此基础上做些文章。
我们的想法是,先用一根单词作为轴,然后将其拓展,每个节点上从左上到右下放入一个新单词,形成一个初步的骨架。
然后再对这个骨架进行其它方向的拓展。
为了更加高效的完成这个方案,我决定用一个估价函数来判断这个骨架是否优秀,显而易见骨架的长宽越大骨架就越差,长宽相差的量越大骨架也越差,而骨架放入的单词越多骨架就越好。这个估价函数由金赢同学完成。
在实现的过程中。
实现过程
由c++实现,主程序不断调用搜索引擎,而搜索引擎会随机的进行乱序,使得生成的骨架不一样。
int main()
{
FILE * fout = fopen(output,"w");
int i,j;
char *a;
bool visited[60];
int minx,miny,maxx,maxy,sum,maxsum;
a = (char *)malloc(sizeof(char)*1000000);
for (int times=0;times<1000;times++)
{
deal(a,&minx,&miny,&maxx,&maxy,&sum,visited);
}
for (i=minx;i<=maxx;i++)
{
for (j=miny;j<=maxy;j++)
{
if (a[i*1000+j]!=' ')
{
fprintf(fout,"%c",a[i*1000+j]);
}
else {fprintf(fout,"_");}
}
fprintf(fout,"\n");
}
string sample(""),pattern;
cout<<endl<<sum<<endl;
}
deal函数的参数,分别表示画板,以及画板的的长宽参数,以及单词的使用情况。
Init()为读入和画板初始化的过程。
Set_skeleton()为骨架搜寻过程,寻找在随机化之后,估价最高的骨架。
Plot()将骨架画在画板上,同时对其进行拓展。
void deal(char *oa,int *ominx,int *ominy,int *omaxx,int *omaxy,int *osum,bool *ovisited)
{
init();
set_skeleton();
plot();
int i,j;
int x,y,x0,y0,sqrt,sqrt0;
x=maxx-minx;y=maxy-miny;sqrt=(x-y)*(x-y);
x0=*omaxx-*ominx;y0=*omaxy-*ominy;sqrt0=(x0-y0)*(x0-y0);
if (sum!=n) return;
if (sum-x/5-y/5-sqrt<=*osum-x0/5-y0/5-sqrt0) return;//plot之后的评价方式
for (i=minx;i<=maxx;i++)
{
for (j=miny;j<=maxy;j++)
{
oa[i*1000+j] = a[i][j];
}
}
*ominx=minx;
*ominy=miny;
*omaxx=maxx;
*omaxy=maxy;
*osum =sum;
for (i=0;i<60;i++) {ovisited[i]=visited[i];}
}
小结
由于一开始规划的不好,整个程序构架出现了较大问题,plot函数由于一开始没有将a[][]画板作为全局变量,导致很多plot的内部实现没有使用函数,情况相当臃肿,另外,一开始想法的出错也拖延了很多时间,所以更加认清楚了软件的提前规划过程是相当重要的。
YBAGIGRPCP____________
___SWODNIW____________
__DATROPOD____________
____ELIFPIZSD_________
_____SOIB_____________
__ESRTENREHTE_________
OCITOMEMMHC___________
_____ERAWYPS__________
________WFAEG____P__WS
________IIOVR___O___EM
________DFNNA__T___UBI
________TIRPT_K_C_S_UL
________HMSEUS_RYEA_SI
_________COKETICB_V_BR
__________OD_WONE_NCUD
___________PEPA_R_EAPA
___________RYM_RSMTCLT
__________I_E___P_IHOA
_________F_____NA_QEAB
______________TECRULDA
________________E_E__S
__________________T__C
这是对题目所给条件的输出
|
Personal Software Process Stages |
时间百分比(%) |
实际花费的时间 (分钟) |
原来估计的时间 (分钟) |
|
|
Planning |
计划 |
5 |
||
|
· Estimate |
· 估计这个任务需要多少时间,把工作细化并大致排序 |
5 |
||
|
Development |
开发 |
85 |
||
|
· Analysis |
· 需求分析 (包括学习新技术) |
15 |
||
|
· Design Spec |
· 生成设计文档 |
10 |
||
|
· Design Review |
· 设计复审 (和同事审核设计文档) |
5 |
||
|
· Coding Standard |
· 代码规范 (制定合适的规范) |
10 |
||
|
· Design |
· 具体设计 |
5 |
||
|
· Coding |
· 具体编码 |
20 |
||
|
· Code Review |
· 代码复审 |
5 |
||
|
· Test |
· 测试(自我测试,修改代码,提交修改) |
15 |
||
|
Reporting |
总结报告 |
10 |
||
|
· Test Report |
· 测试报告 |
5 |
||
|
· Size Measurement |
· 计算工作量 |
3 |
||
|
· Postmortem & Improvement Plan |
· 事后总结, 并提出改进 |
2 |
||
|
Total |
总计 |
100% |
总用时 |
总估计的用时 系数为7小时,与计划差不多~ |
work4的更多相关文章
- python - work4
# -*- coding:utf-8 -*- '''@project: jiaxy@author: Jimmy@file: work_20181108.py@ide: PyCharm Communit ...
- Node.js:进程、子进程与cluster多核处理模块
1.process对象 process对象就是处理与进程相关信息的全局对象,不需要require引用,且是EventEmitter的实例. 获取进程信息 process对象提供了很多的API来获取当前 ...
- 过年7天乐,学nodejs 也快乐
自从上次接触nodejs 已经好长时间了,但是年底公司太忙了 ,没时间看, 上次文章在ubuntu上安装nodejs[开启实时web时代] http://www.cnblogs.com/qqlovin ...
- 前端页面使用 Json对象与Json字符串之间的互相转换
前言 在前端页面很多时候都会用到Json这种格式的数据,最近没有前端,后端的我也要什么都要搞,对于Json对象与Json字符串之间的转换终于摸清楚了几种方式,归纳如下! 一:Json对象转换为json ...
- FR #3题解
A. 傻逼题?...前缀和什么的随便搞搞就好了. #include<iostream> #include<cstdio> #include<cstring> #in ...
- NOI2014 起床困难综合症
3668: [Noi2014]起床困难综合症 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 225 Solved: 153[Submit][Stat ...
- 【模拟】CSU 1807 最长上升子序列~ (2016湖南省第十二届大学生计算机程序设计竞赛)
题目链接: http://acm.csu.edu.cn/OnlineJudge/problem.php?id=1807 题目大意: 给你一个长度为N(N<=105)的数列,数列中的0可以被其他数 ...
- 【博弈论】HDU 5754 Life Winner Bo
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5754 题目大意: 4种棋子,象棋中的 1王,2车,3马,4后,选其一,B和G轮流走,不能往左上走,一 ...
- JDBC控制事务
概念 事务(Transaction)是访问并可能更新数据库中各种数据项的一个程序执行单元(unit).事务通常由高级数据库操纵语言或编程语言(如SQL,C++或Java)书写的用户程序的执行所引起,并 ...
随机推荐
- 2014图灵技术图书最受欢迎TOP15
来自:图灵社区昨晚给我发的邮件,感觉不错,和大家分享,mark下. [小编语] 回首2014,感谢小伙伴们一路相随.让我们2015一起更快乐地玩耍.今天小编为大家盘点一下过去2014年表现最给力的技术 ...
- java匿名对象
java学习面向对象之匿名内部类 之前我们提到“匿名”这个字眼的时候,是在学习new对象的时候,创建匿名对象的时候用到的,之所以说是匿名,是因为直接创建对象,而没有把这个对象赋值给某个值,才称之为匿名 ...
- 将Ftp添加到资源管理器中直接使用
在资源管理器中,右键,添加网络位置. 然后输入ftp的url ftp://server2008 使用匿名方式登录
- bzoj2489
这种题完全可以暴力找规律,暴力打表各种搞法 这里有一篇比较全面的题解:http://acm.uestc.edu.cn/bbs/read.php?tid=3698&page=1&tore ...
- ADODB.Connection 错误 '800a0e7a' 未找到提供程序。该程序可能未正确安装。解决方法!
[问题描述]调试基于ACCESS+ASP的网站程序的时候,遇到如下错误: ADODB.Connection 错误 '800a0e7a' 未找到提供程序.该程序可能未正确安装. /Inc/Functio ...
- UVa 1252 (状压DP + 记忆化搜索) Twenty Questions
题意: 有n个长为m的各不相同的二进制数(允许存在前导0),别人已经事先想好n个数中的一个数W,你要猜出这个数. 每次只可以询问该数的第K为是否为1. 问采用最优询问策略,则最少需要询问多少次能保证猜 ...
- listview默认选择第一项,点击换子项背景图
(不是大神,没有几百子项目,去你丫的) private int last_item_position ; @Override public void onItemClick(AdapterView&l ...
- QPS、PV和需要部署机器数量计算公式(转)
术语说明: QPS = req/sec = 请求数/秒 [QPS计算PV和机器的方式] QPS统计方式 [一般使用 http_load 进行统计] QPS = 总请求数 / ( 进程总数 * 请求 ...
- 基于RTP的H264视频数据打包解包类
from:http://blog.csdn.net/dengzikun/article/details/5807694 最近考虑使用RTP替换原有的高清视频传输协议,遂上网查找有关H264视频RTP打 ...
- 入门视频采集与处理(学会分析YUV数据)
做视频采集与处理,自然少不了要学会分析YUV数据.因为从采集的角度来说,一般的视频采集芯片输出的码流一般都是YUV数据流的形式,而从视频处理(例如H.264.MPEG视频编解码)的角度来说,也是在原始 ...