【现代程序设计】【期末作业】【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实现一个面向主题的网络爬虫程序,并完成以下内容:(注:每人一题,主题内容自选,所有设计内容与源代码需提交到博客园平台) 一.主题式网络爬虫设计方案( ...
随机推荐
- 单交换机VLAN虚拟局域网划分
1.下载Cisco模拟器 Packet Tracer 是由Cisco公司发布的一个辅助学习工具,为学习CCNA课程的网络初学者去设计.配置.排除网络故障提供了网络模拟环境.学生可在软件的图形用户界面上 ...
- cocos2dx开发笔记
1.帧动画:SpriteTest=>SpriteAnimationSplit 2.sourceinsight显示代码行 option->document option->editin ...
- 预定义的类型“Microsoft.CSharp.RuntimeBinder.Binder”未定义或未导入
http://www.mzwu.com/article.asp?id=3611 因为新加了Microsoft.CSharp的引用, 只需要重新生成一下项目,就可以消除这个错误提示
- hdu 4882 ZCC Loves Codefires (贪心 推导)
题目链接 做题的时候凑的规律,其实可以 用式子推一下的. 题意:n对数,每对数有e,k, 按照题目的要求(可以看下面的Hint就明白了)求最小的值. 分析:假设现在总的是sum, 有两个e1 k1 e ...
- Android之ScaleGestureDetector(缩放手势检测)
一.概述 ScaleGestureDetector这个类是专门用来检测两个手指在屏幕上做缩放的手势用的,最简单的应用就是用来缩放图片或者缩放网页. 二.要求 利用ScaleGestureDetecto ...
- UVa 11361 (计数 递推) Investigating Div-Sum Property
题意: 统计[a, b]中有多少个数字满足:自身是k的倍数,而且各个数字之和也是k的倍数. 分析: 详细分析见<训练之南>吧,=_=|| 书上提出了一个模板的概念,有了模板我们就可以分块计 ...
- HNOI2010弹飞绵羊
不得不说块状数组好神奇的啊!这道题的标签可是splay的启发是合并(什么高大上的东西),竟然这么轻松的就解决了! var x,y,i,j,tot,n,m,ch:longint; f,k,l,bl,go ...
- OK335xS psplash make-image-header.sh hacking
/***************************************************************************** * OK335xS psplash mak ...
- Java Socket(3): NIO
NIO采取通道(Channel)和缓冲区(Buffer)来传输和保存数据,它是非阻塞式的I/O,即在等待连接.读写数据(这些都是在一线程以客户端的程序中会阻塞线程的操作)的时候,程序也可以做其他事情, ...
- test chemes
rcmobile://messages rcmobile://badge rcmobile://dialer rcmobile://open rcmobile://sms?type=new