C#实现生成所有不重复的组合功能示例

本文实例讲述了C#实现生成所有不重复的组合功能。分享给大家供大家参考,具体如下:

给你几个字母,比如(a,b,c,d,e,f),要求生成所有不重复的组合。

这里重复的定义是这样的,任意两个元素个数相同的组合,如果其包含的元素均两两相等,即视为重复,例如abc和cba就是重复。

嗯,大概意思就是这样,下面给出代码。

static void Main(string[] args)
{      
  string[] values = { "a", "b", "c", "d" };
  string s;
  for (int i = 1; i < Math.Pow(2, values.Length) - 1; i++)
  {
    s = "";
    for (int j = 0; j < values.Length; j++)
    {
      if ((i & (int)Math.Pow(2, j)) == Math.Pow(2, j))
        s += values[j];
    }
    Console.Write("{0} ",s);
  }
  Console.Read();
}

运行结果:

更多关于C#相关内容感兴趣的读者可查看本站专题:《C#数据结构与算法教程》、《C#程序设计之线程使用技巧总结》、《C#常见控件用法教程》、《WinForm控件用法总结》、《C#数组操作技巧总结》及《C#面向对象程序设计入门教程》

希望本文所述对大家C#程序设计有所帮助。

声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:notice#nhooo.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。