using System;
using System.Collections.Generic;
using System.Linq;
using System.Text; using Microsoft.Practices.EnterpriseLibrary.Validation.Validators;
using Microsoft.Practices.EnterpriseLibrary.Validation; namespace ConsoleApplication1
{
class Program
{
static void Main(string[] args) { int[] arr = new int[] {10,5,3,6,8,9,7};
int[] recode = new int[arr.Length];
recode[0] = 1;
//求数组中最长非降 子序列
for (int i = 1; i < arr.Length; i++)
{
if (arr[i] > arr[i - 1])
recode[i] = recode[i-1]+1;
else
recode[i] = recode[i-1]; }
for (int i = 0; i < recode.Length ; i++)
{
Console.WriteLine("到第"+(i+1)+"元素的最长非降 子序列长度:"+recode[i]);
}
Console.Read(); }
} }

  执行结果 :这里保存了到某个长度下的所有状态 如果不需要 完全可以用int变量存储 不需要使用数组 这样复杂度分别为 o(n),o(1)

 

问题

一个序列有N个数:A[1],A[2],…,A[N],求出最长非降子序列的长度

 分析 我先用列举法考虑简单情况 然后找规律

  第一个元素最长非降序列长度肯定为1 因为只有本身 没有比较对象 记为 f(1)=1

  到第二个元素 与第一个元素进行对比 如果小于第一个元素 那么这里第二个元素并没有为长度做出贡献 状态还保持在上一个元素 记 f(2)=1=f(1)

  以此类推

  最后得到以上结果

  

这是我对动态规划的入门理解 即之前最优的状态影响着当前状态 而上一个状态就是在这之前的最优状态  这样也能降低算法的复杂程度

第二例

代码

  

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text; using Microsoft.Practices.EnterpriseLibrary.Validation.Validators;
using Microsoft.Practices.EnterpriseLibrary.Validation; namespace ConsoleApplication1
{
public class NodeDistance
{
/// <summary>
/// 节点名称
/// </summary>
public string nodeName { get; set; }
/// <summary>
/// 能到达的节点及与他们的距离列表
/// </summary>
public List<(string nodeName, int distance)> distance { get; set; } }
class Program
{
//记录已到达的(走到当前的)最短路径
static (string lujin, int distance) luxianDaoDa = ("", int.MaxValue); static void Main(string[] args)
{ // 问题 无向图上有N(1<N)个节点 每个节点有任意长的距离 计算任意节点A到任意节点B的距离
//使用二维数组模拟点的情况 以及单个点到其他点的距离 先从简单的情况开始考虑 有abcd四个节点 每个节点可以到达其他节点 List<NodeDistance> nodeList = new List<NodeDistance>() {
new NodeDistance
{
nodeName="a",
distance=new List<(string nodeName, int distance)>{
("b",2),("c",7),("c",7)
}
},
new NodeDistance
{
nodeName="b",
distance=new List<(string nodeName, int distance)>{
("a",2),("c",3),("d",2)
}
},
new NodeDistance
{
nodeName="c",
distance=new List<(string nodeName, int distance)>{
("a",7),("d",5),("b",3)
}
},
new NodeDistance
{
nodeName="d",
distance=new List<(string nodeName, int distance)>{
("a",6),("c",3),("b",2)
}
}, };
List<(string lujin, int distance)> luxian = new List<(string lujin, int distance)>(); //求a-c得最短路径
CalcDistance("a", "c", "a", 0, nodeList);
Console.WriteLine("最短路径:" + luxianDaoDa.lujin + "距离为:" + luxianDaoDa.distance);
Console.Read(); } /// <summary>
/// 计算距离
/// </summary>
/// <param name="node">当前节点</param>
/// <param name="endChar">结束位置</param>
public static void CalcDistance(string startChar, string endChar, string luxianName, int distance, List<NodeDistance> nodeList)
{
var node = nodeList.Where(u => u.nodeName == startChar).FirstOrDefault();
//记录走过的节点
foreach (var item in node.distance)
{
//判断当前节点是否走过 或者是否为起点
if (item.nodeName == "a") continue;
luxianName += item.nodeName;
// 判断是否为当前情况下的最优状态 如果是 判断是否为终点
distance += item.distance;
if (distance >= luxianDaoDa.distance) continue;
if (item.nodeName == endChar)
luxianDaoDa = (luxianName, distance);
else
CalcDistance(item.nodeName
, endChar, luxianName, distance, nodeList); } } } }

  运行结果

  

抽屉取苹果

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text; using Microsoft.Practices.EnterpriseLibrary.Validation.Validators;
using Microsoft.Practices.EnterpriseLibrary.Validation; namespace ConsoleApplication1
{ class Program
{ static int[][] apple = new int[3][];
static int[][] appleSum = new int[3][]; static void Main(string[] args) {
apple[0] = new int[] {3,2,4};
apple[1] = new int[] { 2,1,3 };
apple[2] = new int[] { 6,5,1};
appleSum[0] = new int[apple[0].Length];
appleSum[1] = new int[apple[0].Length];
appleSum[2] = new int[apple[0].Length]; appleSum[0][0] = apple[0][0];//初始只能取到本身
//先填充第一行与第一列
for (int i = 1; i < apple.Length; i++)
{
appleSum[0][i] = appleSum[0][i - 1] + apple[0][i];
appleSum[i][0] = appleSum[i-1][0] + apple[i][0]; }
//当前位置记为array[x][y] 然后填充其他行与列 值为max(array[x+1][y],array[x][y+1])
for (int x = 1; x < apple.Length; x++)
for (int y = 1; y < apple[0].Length; y++)
appleSum[x][y]= (appleSum[x - 1][y] > appleSum[x][y - 1] ? appleSum[x - 1][y] : appleSum[x][y - 1])+apple[x][y]; Console.WriteLine("最大值:"+appleSum[apple.Length-1][apple[0].Length-1]); Console.Read();
} } }

  

  

具体分析  http://www.cnblogs.com/lihonglin2016/p/4298432.html

  

  

  

动态规划初级 入门理解 C#代码的更多相关文章

  1. Sping AOP初级——入门及简单应用

    在上一篇<关于日志打印的几点建议以及非最佳实践>的末尾提到了日志打印更为高级的一种方式——利用Spring AOP.在打印日志时,通常都会在业务逻辑代码中插入日志打印的语句,这实际上是和业 ...

  2. Spring AOP初级——入门及简单应用

      在上一篇<关于日志打印的几点建议以及非最佳实践>的末尾提到了日志打印更为高级的一种方式——利用Spring AOP.在打印日志时,通常都会在业务逻辑代码中插入日志打印的语句,这实际上是 ...

  3. mui初级入门教程(四)— 再谈webview,从小白变“大神”!

    文章来源:小青年原创发布时间:2016-06-05关键词:mui,html5+,webview转载需标注本文原始地址: http://zhaomenghuan.github.io/#!/blog/20 ...

  4. mui初级入门教程(三)— html5+ XMLHttpRequest 与mui ajax用法详解

    文章来源:小青年原创发布时间:2016-05-29关键词:mui,html5+,XMLHttpRequest,ajax,懒加载转载需标注本文原始地址: http://zhaomenghuan.gith ...

  5. 响应式Web初级入门

    本文来自我的前端博客,原文地址:http://www.hacke2.cn/about-responsive/ 跨终端时代的到来 当你乘坐各种交通工具(公交.地铁.轻轨.火车)时你会发现,人们都个个低下 ...

  6. hadoop入门手册5:Hadoop【2.7.1】初级入门之命令:文件系统shell2

    问题导读 1.改变hdfs文件的权限,需要修改哪个配置文件?2.获取一个文件的或则目录的权限,哪个命令可以实现?3.哪个命令可以实现设置访问控制列表(ACL)的文件和目录? 接上篇:Hadoop[2. ...

  7. hadoop入门手册4:Hadoop【2.7.1】初级入门之命令:文件系统shell1

    问题导读1.Hadoop文件系统shell与Linux shell有哪些相似之处?2.如何改变文件所属组?3.如何改变hdfs的文件权限?4.如何查找hdfs文件,并且不区分大小写? 概述文件系统 ( ...

  8. hadoop入门手册3:Hadoop【2.7.1】初级入门之命令指南

    问题导读1.hadoop daemonlog管理员命令的作用是什么?2.hadoop如何运行一个类,如何运行一个jar包?3.hadoop archive的作用是什么? 概述 hadoop命令被bin ...

  9. Spring Cloud实战之初级入门(六)— 服务网关zuul

    目录 1.环境介绍 2.api网关服务 2.1 创建工程 2.3 api网关中使用token机制 2.4 测试 2.5 小结 3.一点点重要的事情 1.环境介绍 好了,不知不觉中我们已经来到了最后一篇 ...

随机推荐

  1. 【map】【分解质因数】CDOJ1572 Espec1al Triple

    先把公比为1,即前项 中项 末项相同的统计出来.对每一类数C(n,3)即可. 然后我们发现,因为a1*a3=(a2)^2,所以a1和a3进行质因子分解之后,每一个质因子的指数的奇偶性必然相同,否则无法 ...

  2. [BalkanOI2016]Cruise

    题目大意: 平面直角坐标系内有n个点,每个点有一个点权. 你从原点p出发,走若干个点然后回到原点. 两个点之间只能笔直走,你的收获为你的路径围起来的区域内的所有店权和除以路径长度. 问最大收益. 思路 ...

  3. UI Watcher 解决不定时弹窗问题

    缘来是你: 在基于UI谷歌库的测试系统对第三方APK测试例,存在不定时弹窗问题,对测试例的健壮性和稳定性产生了很大影响. 为了解决这个问题,谷歌开源了UIwatcher 类来解决此问题. 附谷歌官网类 ...

  4. TabControl控件和TabPage

    TabControl控件和TabPageTabControl控件可以支持在一个控件里面放置多个选项卡,每个选项卡又可以放置多个控件 由于在控件属性窗口添加选项卡相对比较容易,下面说一下动态创建选项卡 ...

  5. 最好的拖拽js

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  6. Linux操作系统下的常见系统资源共享

    转:http://www.360doc.com/content/07/0420/10/25127_457022.shtml linux下如何挂接(mount)光盘镜像文件.移动硬盘.U盘.Window ...

  7. 推荐一篇讲arm架构gcc内联汇编的文章

    这是来自ethernut网站的一篇文章,原文链接: http://www.ethernut.de/en/documents/arm-inline-asm.html 另外,据说nut/os是个不错的开源 ...

  8. Oracle 11gR2 RAC的两个bug

      Oracle 11.2.0.2 bug还是不少的.很多库迁到Oracle 11.2.0.2后都遇到了问题.现在正在跟的两个Oracle 11.2.0.2上的问题:1.ORA-00600: inte ...

  9. unitest跳过测试用例

    http://www.51testing.com/html/35/n-3718035.html @unittest.skip(u"强制跳过示例") @unittest.skip(u ...

  10. response letter模板

    Dear Dr. or Prof. XXXX (family name of the Editor or Editor-in-Chief who issued the decision letter) ...