【现代程序设计】【期末作业】【homework-09】
作业要求说明:
http://www.cnblogs.com/xinz/p/3441537.html
我在做一个什么样的应用:
展示如何逐步求解一个加权矩阵的
- 最大子矩阵
- 最大子联通图
下面是软件的截图

包含的基本功能:
- 从文件读入矩阵随机生成矩阵
- 本软件将保存最近使用的3个文件(若包含当前正在使用的文件,则为4个)
- 随机生成矩阵
- 可设置矩阵的大小,不超过10*10
- 超过10*10将导致anymaxsum步骤过多,而没有什么教学意义了。
- 播放
- 自动
- 随时调整播放间隔(播放中亦可)
- 手动
- 回退和下一步
- 重置
- 选择播放类型
结果展示:(包含一个矩阵和两个文本框)
- 矩阵:用于显示详细步骤和状态(详细见软件)
- 最大值(文本框):显示当前最大值
- 当前值(文本框):显示当前选定值
应用设计语言和平台:
- 语言:C#+XAML
- 运行平台:.Net 4.0+ and 浏览器(IE9+)
什么工作占用了我比较大的时间?
GUI的设计
思考到底怎样的设计才能让初学者理解DP动态规划执行的过程和原理,而不是看着动画一闪而过,完全不明白整个过程是在做什么。
- 例子需简单,即矩阵不能包含过多的元素,4*4,5*5,6*6是可接受的值。
- 执行过程需可控,用户可以选择手动或者自动模式,自动模式下,播放速度可以调节。
- 每一个中间步骤需要有对应的解释说明,解释还需要贴合人们的思维模式,比如 a.红色代表错误 b.绿色代表可行。
- 用户大多数时候都在看算法执行的过程,因此初始值相关的GUI控件应该只占用小部分空间
- 【停止】,【播放】,【上一步】等等控件应该被设计的比较大,因为它们会被访问的更频繁。
下面是该软件的详细设计时遇到几个问题:
安全问题,浏览器文件访问权限
浏览器端的应用均运行于沙盒之中,所以浏览器无法直接使用使用文件选取器
解决办法
提升应用的权限,在属性中更改
如何将二维数组绑定到控件 DataGrid?
代码DataGrid
<DataGrid x:Name="dataGrid" ItemsSource="{Binding CollectionSource}" SelectionUnit="CellOrRowHeader" IsReadOnly="True" MaxColumnWidth="100" MinColumnWidth="100" AutoGenerateColumns="True" CanUserResizeRows="False" CanUserSortColumns="False" CanUserReorderColumns="False" LoadingRow="dataGrid_LoadingRow" HorizontalAlignment="Center" VerticalAlignment="Center" AutoGeneratedColumns="dataGrid_AutoGeneratedColumns" AutoGeneratingColumn="dataGrid_AutoGeneratingColumn" Margin="0,0,0,30" FontSize="20" FontFamily="Segoe UI">
<DataGrid.ColumnHeaderStyle>
<Style TargetType="DataGridColumnHeader">
<Setter Property="HorizontalContentAlignment" Value="Center"/>
<Setter Property="Background" Value="AliceBlue" />
<Setter Property="Foreground" Value="Black"/>
<Setter Property="FontSize" Value="20" />
</Style>
</DataGrid.ColumnHeaderStyle>
</DataGrid>
PageSource
<Page.Resources>
<DataTemplate x:Key="CellTemplate">
<TextBlock Background="{Binding Back}" Text="{Binding Value}" TextAlignment="Center" Foreground="White"/>
</DataTemplate> </Page.Resources>
首先,在PageSource 里面申明了一个CellTemplate,将DataGrid 每一个Cell 设置为 一个TextBlock
后台定义了一个类 item,包含元素 Back,Value
分别对应该TextBlock的Background和Text两个属性
定义了 一个 继承于 ObservableCollection<item> items 收集DataGrid每一行的数据
并定义了一个 ObservableCollection<items> CollectionSource,收集DataGrid所有行的数据
再在DataGrid代码里将 ItemsSource绑定到CollectionSource: [ItemsSource="{Binding CollectionSource}"]
后台算法
因在第三次作业中已经完成了这部分工作
所以这次作业,我只是在maxsum类中加入了两个属性:
并设置了访问器
在实体化maxsum类之后,便可以直接获取数据
/// <summary>
/// 结果存储于下面两个list
/// result_maxsum 矩阵
/// result_any_maxsum 任意
/// </summary>
public List<step_detail> result_maxsum { get; set; }
public List<step_detail> result_any_maxsum { get; set; }
几个测试用例




完整代码:
https://github.com/11061027zsx/homework-09/
【现代程序设计】【期末作业】【homework-09】的更多相关文章
- SDN期末作业验收
作业链接:https://edu.cnblogs.com/campus/fzu/SoftwareDefinedNetworking2017/homework/1585 负载均衡程序 1.github链 ...
- 分享:计算机图形学期末作业!!利用WebGL的第三方库three.js写一个简单的网页版“我的世界小游戏”
这几天一直在忙着期末考试,所以一直没有更新我的博客,今天刚把我的期末作业完成了,心情澎湃,所以晚上不管怎么样,我也要写一篇博客纪念一下我上课都没有听,还是通过强大的度娘完成了我的作业的经历.(当然作业 ...
- C语言程序设计第一作业
C语言程序设计第一作业 实验总结 (一) 1.题目:输入圆的半径,求圆周长和面积 2.流程图: 3.测试数据及运行结果: 4.实验分析: 问题1: 出现了错误 原因:是在赋值那写反了 解决方法:应该是 ...
- # C语言程序设计第一次作业1234
---恢复内容开始--- C语言程序设计第一次作业 1.求圆面积和周长 输入圆的半径,计算圆的周长和面积 (1)流程图 (2)测试数据及运行结果 测试数据r=3 运行结果 2.判断闰年 输入一个四位年 ...
- SDN期末作业——负载均衡
作业链接 期末作业 1.负载均衡程序 代码 2.演示视频 地址 3.小组分工 小组:incredible five 构建拓扑:俞鋆 编写程序:陈绍纬.周龙荣 程序调试和视频录制:陈辉.林德望 4.个人 ...
- SDN 期末作业验收
前言 SDN 期末作业验收我们是采用的参考场景一,我们在此场景的基础上来做负载均衡,下面是我们搭建的拓扑图 演示视频 https://pan.baidu.com/s/1htkKLPM 负载均衡程序 相 ...
- [毕业设计][期末作业]二手闲置小程序 免费信息发布系统功能源码(小程序+php后台管理)
最近做了一个小程序,主要是二手闲置免费信息发布系统的功能,里面包括了登录,发布商品,商品管理,违规投诉,canva商品海报生成,分享等一些基础的功能,可以说代码都是自己辛辛苦苦写出来的.可作为毕业设计 ...
- Week11《java程序设计》作业总结
Week11<java程序设计>作业总结 1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多线程相关内容. 答: 2. 书面作业 本次PTA作业题集多线程 1. 源代码 ...
- week10《java程序设计》作业总结
week10<java程序设计>作业总结 1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结异常相关内容. 答:: 2. 书面作业 本次PTA作业题集异常 1. 常用异常 ...
- Python高级应用程序设计任务期末作业
Python高级应用程序设计任务要求 用Python实现一个面向主题的网络爬虫程序,并完成以下内容:(注:每人一题,主题内容自选,所有设计内容与源代码需提交到博客园平台) 一.主题式网络爬虫设计方案( ...
随机推荐
- 关于java.lang.NoClassDefFoundError: com/sun/mail/util/LineInputStream解决办法
吉林的一个项目有个错误找了一天,有段报错是: java.lang.NoClassDefFoundError: com/sun/mail/util/LineInputStream 1.遇到过两次,第 ...
- 重写hashCode()的方法
重写hashCode()方法的基本规则: 1.在程序运行过程中,同一个对象多次调用hashCode()方法应该返回相同的值 2.当两个对象通过equals()方法比较返回true时,这两个对象的has ...
- android.content.Context 含义及使用
Context字面意思上下文,位于framework package的android.content.Context中,其实该类为LONG型,类似Win32中的Handle句柄,很多方法需要通过Con ...
- unity3d5.2.3中 调整视角
按住alt键不放,然后左边的手的图标会变成一个眼睛,在Scene中移动.就会发现可以调整视角了
- 函数buf_read_page
/********************************************************************//** High-level function which ...
- 函数buf_page_address_fold
/********************************************************************//** Calculates a folded value ...
- iOS开发:iOS的整体架构以及API介绍
iOS的整体架构分为4层——Cocoa Touch层.Media层.Core Services层和Core OS层,下面概要介绍一下这4层. Cocoa Touch:构建iOS应用的一些基本系统服务, ...
- BZOJ_1029_[JSOI2007]_建筑抢修_(贪心+优先队列)
描述 http://www.lydsy.com/JudgeOnline/problem.php?id=1029 \(n\)个任务需要完成,给出每个任务所需时间\(t_1\)与deadline\(t_2 ...
- [反汇编练习]160个CrackMe之001
[反汇编练习] 160个CrackMe之001. 本系列文章的目的是从一个没有任何经验的新手的角度(其实就是我自己),一步步尝试将160个CrackMe全部破解,如果可以,通过任何方式写出一个类似于注 ...
- noip2000提高组题解
事实再次向我证明了RP的重要性... 第一题:进制转换 是我最没有把握AC的一道题目却是我唯一一道AC的题目,真是讽刺.看完题目几乎完全没有往正常的解法(取余倒序)去想,直接写了搜索,因为数据范围在2 ...