zoukankan      html  css  js  c++  java
  • C# 算法系列

    using System;
     
    namespace ConsoleApp1
    {
        class Program
        {
            static void Main(string[] args)
            {
                /*===========贪婪算法-背包问题==============
                    背包问题(Knapsack problem)是一种组合优化的NP完全问题。
                    问题可以描述为:给定一组物品,每种物品都有自己的重量和价格,在限定的总重量内,我们如何选择,才能使得背包里物品的总价格最高。
                    问题的名称来源于如何选择最合适的物品放置于给定背包中。
                    相似问题经常出现在商业、组合数学,计算复杂性理论、密码学和应用数学等领域中。
                    也可以将背包问题描述为决定性问题,即在总重量不超过W的前提下,总价值是否能达到V             
                 */
                //货物重量和价值
                int[,] a;
                //背包承重
                int w;
                //测试数据,答案是334
                a = new int[,] { { 79, 58, 86, 11, 28, 62, 15, 68 }, { 83, 14, 54, 79, 72, 52, 48, 62 } };
                w = 200;
                int v; //最大价值
                v = GetMaxValue(w, a, 0);
                Console.WriteLine($"背包能实现的最大价值为:{v}");
                Console.ReadKey();
            }
     
            /// <summary>
            /// 获得背包承重w,装货物o,从第k件向后考虑,得到的最大价值
            /// </summary>
            /// <param name="w">背包承重</param>
            /// <param name="o">货物o</param>
            /// <param name="k">第几件开始默认索引0</param>
            /// <returns></returns>
            public static int GetMaxValue(int w, int[,] o, int k)
            {
                int v, t1, t2;
                //如果是最后一件货物
                if (k == o.GetLength(1) - 1)
                {
                    if (w >= o[0, k])
                    {
                        v = o[1, k];
                    }
                    else
                    {
                        v = 0;
                    }
                }
                //如果装得下当前货物
                else if (w >= o[0, k])
                {
                    t1 = GetMaxValue(w - o[0, k], o, k + 1) + o[1, k];
                    t2 = GetMaxValue(w, o, k + 1);
                    v = GetMax(t1, t2);
                }
                //装不下当前货物的情况
                else
                {
                    v = GetMaxValue(w, o, k + 1);
                }
                return v;
            }
            public static int GetMax(int a, int b)
            {
                return a > b ? a : b;
            }
     
        }
    }

    MSCL超级工具类库
    基于C#开发的超强工具类,包含数据库操作,字符串处理,文件或者文件夹处理
    网络请求,缓存处理,数据容器等上百个常用工具类封装,附带调用示例和参数说明,
    提供CHM详细文档,上百个生产环境使用,稳定高效,简单易用。
    真正做到“工具在手,一切尽有”,让你大幅度的提高编程效率,提高编程水平。
    联系QQ:7400799(请备注 "MSCL")

    ===============================================

    重要压缩文件忘记解压密码?网上下载rar/zip/7z等压缩文件,需要密码?
    ====极速解密助手,支持支持RAR/ZIP/7Z等多种压缩文档解密======
    ★ 解密不超过24小时,跟密码复杂程度相关
    ★ 解密成功后再收费,无套路
    ★ 解密成功后自动删除原件,无后顾之忧
    联系QQ:7400799(请备注 "文件解密")

    ==============================================

    Magic.Orm已在数百个成熟项目中应用,是比较完善的ORM框架(基于C#开发)。开发过程中参考了NBear与MySoft,吸取了其中的一些精华,加入新思想,
    后期参考EF的Lambda语法进行大量扩展。

    为什么选择Magic.Orm?

    • 上手简单,0学习成本。使用方便,按照sql书写习惯编写C#.NET代码。功能强大。
    • 高性能,接近手写Sql。
    • 体积小(不到200kb,仅一个dll)。
    • 完美支持Sql Server(2000至最新版),MySql,Oracle,Access,Sqlite等数据库。
    • 支持大量Lambda表达式写法。
    • 不需要像NHibernate的XML配置,不需要像EF的各种数据库连接驱动,集成简单。

    购买源码 请联系QQ:7400799(请备注 "ORM")

  • 相关阅读:
    android sdk manager 更新问题
    Java static的使用 --Java笔记
    day98-django-ORM操作,创建表,表的增删改查,CBV操作
    day97-django-自带分页
    day96-django-分页模块(自定义)
    day95-django-子版继承母版
    day94-django-cookie登录校验
    day92-django-pymysql操作mysql封装之优化版,自定义的sqlhelper.py模块
    day91-django学生列表之增删改查(模态框-ajax提交)
    day90-django学生列表之增删改查(form提交)、思路、关于ajax的知识点
  • 原文地址:https://www.cnblogs.com/smartsmile/p/14419022.html
Copyright © 2011-2022 走看看