zoukankan      html  css  js  c++  java
  • 任意数相加求和

    在网上看到一端代码,觉得很新颖,特此记录下来以供大家学习参考:

    用C#写一个函数。功能如下:
    任意给定一组数,例如{12,60,-8,99,15,35,17,18},
    找出任意数相加(不能重复)之后的结果为35(任意设定)的情况
    例如:12+8+15; 35; 17+18。

    算法如下:

         private static readonly int[] values = {12,60,8,99,15,35,17,18 };
         private const int toltal = 35;

           private void Test()
            {
                Array.ForEach(Array.FindAll(values,x=>x==toltal),Console.WriteLine);
                Dictionary<string, int> dic = new Dictionary<string, int>();
                for (int i = 0; i < values.Length; i++)
                {
                    dic.Add(values[i].ToString(), i);
                }
                GetString(dic);
                Console.ReadLine();
            }

            private static void GetString(Dictionary<string,int> dd)
            {
                Dictionary<string, int> dic = new Dictionary<string, int>();
                foreach (KeyValuePair<string, int> kv in dd)
                {
                    for (int i = kv.Value + 1; i < values.Length; i++)
                    {
                        string calc = kv.Key + "+" + values[i];
                        if (Convert.ToInt32(new DataTable().Compute(calc, null)) == toltal)
                        {
                            Console.WriteLine(calc);
                        }
                        dic.Add(kv.Key+"+"+values[i],i);
                    }
                }
                if (dic.Count > 0)
                    GetString(dic);
            }

  • 相关阅读:
    金蝶报错事项
    ROS的脚本多拨
    zabbix4.0 相关的拓扑图及centos的虚拟配置
    ros开启快速转发模式
    linux 配置 l2tp-client
    linux 系统管理 实战技巧
    Flunetd 用于统一日志记录层的开源数据收集器
    在Centos7 更改Docker默认镜像和容器的位置
    Supervisor: 进程控制系统
    如何用正确的姿势查看 主机系统的CPU信息
  • 原文地址:https://www.cnblogs.com/xiaolifeidao/p/3770291.html
Copyright © 2011-2022 走看看