[整理]枚举双色球的红球所有排列组合的SQL

由数学上的排列组合可以计算出来,由于双色球不排序,只组合,所以33红球和16篮球全选的话有   17721088种可能。

--电脑很慢,用了3:46"
;WITH CTE AS
(
SELECT TOP 33 ID=ROW_NUMBER() OVER (ORDER BY GETDATE()) FROM syscolumns
)
,CTE2 AS
(
SELECT ID,CAST(ID AS VARCHAR(8000)) AS COP,LVL=1 FROM CTE
UNION ALL
SELECT CTE.ID,COP=COP+','+RTRIM(CTE.ID),LVL+1 FROM CTE,CTE2 WHERE CTE.ID<CTE2.ID AND LVL<6
)
SELECT ROW_NUMBER() OVER (ORDER BY GETDATE()),COP FROM CTE2 WHERE LVL=6
/*
                     COP
-------------------- ---------------------------------------------------------
1                    33,32,31,30,29,1
2                    33,32,31,30,29,2
3                    33,32,31,30,29,3
4                    33,32,31,30,29,4
5                    33,32,31,30,29,5
6                    33,32,31,30,29,6
..........
1107564              7,6,5,4,2,1
1107565              7,6,5,3,2,1
1107566              7,6,4,3,2,1
1107567              7,5,4,3,2,1
1107568              6,5,4,3,2,1


(1107568 row(s) affected)
*/


【SQLServer】

SELECT TOP 33 id=identity(int,1,1) INTO #1 FROM sysobjects

SELECT A.id ,B.id,C.id,D.id,E.id,F.id 
FROM #1 A,#1 B,#1 C,#1 D,#1 E,#1 F
WHERE A.ID<B.ID AND A.ID<C.ID AND A.ID<D.ID AND A.ID<E.ID AND A.ID<F.ID
AND B.ID<C.ID AND B.ID<D.ID AND B.ID<E.ID AND B.ID<F.ID
AND C.ID<D.ID AND C.ID<E.ID AND C.ID<F.ID
AND D.ID<E.ID AND D.ID<F.ID
AND E.ID<F.ID
ORDER BY A.id,B.id,C.id,D.id,E.id,F.id

--result : 1107568 SQL Server 2005 46's

-- 创建号码表(1-33)tb_rednum

SELECT TOP 33 id=identity(int,1,1) INTO dbo.tb_rednum FROM sysobjects

-- 创建结果表 (所有组合) tb_allred

SELECT A.id num01 ,B.id num02,C.id num03,D.id num04,E.id num05,F.id num06 into dbo.tb_allred

FROM tb_rednum A,tb_rednum B,tb_rednum C,tb_rednum D,tb_rednum E,tb_rednum F
WHERE A.ID<B.ID AND A.ID<C.ID AND A.ID<D.ID AND A.ID<E.ID AND A.ID<F.ID
AND B.ID<C.ID AND B.ID<D.ID AND B.ID<E.ID AND B.ID<F.ID
AND C.ID<D.ID AND C.ID<E.ID AND C.ID<F.ID
AND D.ID<E.ID AND D.ID<F.ID
AND E.ID<F.ID

引自:http://blog.csdn.net/flyloafer/article/details/5221137     徐哲


【Oracle】

With X As (Select Rownum Id From Dict Where Rownum<33)
Select A.Id R1,B.Id R2,C.Id R3,D.Id R4,E.Id R5,F.Id R6
From X A,X B,X C,X D,X E,X F
Where A.Id<B.Id And A.Id<C.Id And A.Id<D.Id And A.Id<E.Id And A.Id<F.Id
And B.Id<C.Id And B.Id<D.Id And B.Id<E.Id And B.Id<F.Id
And C.Id<D.Id And C.Id<E.Id And C.Id<F.Id
And D.Id<E.Id And D.Id<F.Id
And E.Id<F.Id
Order By A.Id,B.Id,C.Id,D.Id,E.Id,F.Id;


 双色球彩票33选6算法:M个数N个为一组,所有无重复的排列组合

 应朋友请求做的双色球彩票33选6算法:M个数N个为一组,所有无重复的排列组合。测试基本没问题,欢迎彩票迷们使用!

   private void button1_Click(object sender, EventArgs e)
        {
            int nCnt = 0;
            List<int> nNumList = new List<int>();
            for (int i = 0; i < cblNumList.Items.Count; i++)
            {
                if (cblNumList.GetItemChecked(i))
                {
                    nNumList.Add(Convert.ToInt32(cblNumList.Items[i].ToString()));
                }
            }
            System.Text.StringBuilder sbResult = new StringBuilder();

            int nLast = nNumList.Count;

            for (int i1 = 0; i1 < nLast-5; i1++)
            {
                for (int i2 = 0; i2 < nLast - 4; i2++)
                {
                    if (i2 == i1) continue;
                    for (int i3 = 0; i3 < nLast - 3; i3++)
                    {
                        if (i3 == i2 || i3 == i1) continue;
                        for (int i4 = 0; i4 < nLast - 2; i4++)
                        {
                            if (i4 == i3 || i4 == i2 || i4 == i1) continue;
                            for (int i5 = 0; i5 < nLast - 1; i5++)
                            {
                                if (i5 == i4 || i5 == i3 || i5 == i2 || i5 == i1) continue;
                                for (int i6 = 0; i6 < nLast; i6++)
                                {
                                    if (i6 == i5 || i6 == i4 || i6 == i3 || i6 == i2 || i6 == i1) continue;
                                    if (nNumList[i1] > nNumList[i2] || nNumList[i2] > nNumList[i3] || nNumList[i3] > nNumList[i4] || nNumList[i4] > nNumList[i5] || nNumList[i5] > nNumList[i6]) continue;
                                    sbResult.Append("\r\n" + nNumList[i1].ToString() + " " + nNumList[i2].ToString() + " " + nNumList[i3].ToString() + " " + nNumList[i4].ToString() + " " + nNumList[i5].ToString() + " " + nNumList[i6].ToString());
                                    nCnt += 1;
                                }
                            }
                        }
                    }
                }
            }
            tbResult.Text = sbResult.ToString();
            //lblMessage.Text = nLast + " 个随机数字;共有 " + nCnt + " 条记录";

        }


  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
可以使用递归来实现字符串的排列组合。具体步骤如下: 1. 定义一个递归函数,传入当前已经排列好的字符串和剩余待排列的字符串。 2. 如果待排列字符串为空,则输出当前已经排列好的字符串。 3. 否则,依次将待排列字符串中的每个字符加入已排列字符串中,并递归调用自身,直到待排列字符串为空。 下面是一个示例代码,可以枚举出1-n的所有组合,然后随机选取任意多个。 ```java import java.util.ArrayList; import java.util.List; import java.util.Random; public class PermutationCombination { public static void main(String[] args) { int n = 5; List<String> list = new ArrayList<>(); for (int i = 1; i <= n; i++) { list.add(String.valueOf(i)); } List<String> result = new ArrayList<>(); permutation("", list, result); System.out.println("所有组合:"); for (String s : result) { System.out.println(s); } System.out.println("\n随机选取任意多个:"); Random random = new Random(); for (int i = 0; i < 5; i++) { int num = random.nextInt(result.size()); System.out.println(result.get(num)); } } private static void permutation(String prefix, List<String> list, List<String> result) { if (list.isEmpty()) { result.add(prefix); } else { for (int i = 0; i < list.size(); i++) { List<String> newList = new ArrayList<>(list); String newPrefix = prefix + newList.remove(i); permutation(newPrefix, newList, result); } } } } ``` 输出结果如下: ``` 所有组合: 12345 12354 12435 12453 12534 12543 13245 13254 13425 13452 13524 13542 14235 14253 14325 14352 14523 14532 15234 15243 15324 15342 15423 15432 21345 21354 21435 21453 21534 21543 23145 23154 23415 23451 23514 23541 24135 24153 24315 24351 24513 24531 25134 25143 25314 25341 25413 25431 31245 31254 31425 31452 31524 31542 32145 32154 32415 32451 32514 32541 34125 34152 34215 34251 34512 34521 35124 35142 35214 35241 35412 35421 41235 41253 41325 41352 41523 41532 42135 42153 42315 42351 42513 42531 43125 43152 43215 43251 43512 43521 45123 45132 45213 45231 45312 45321 51234 51243 51324 51342 51423 51432 52134 52143 52314 52341 52413 52431 53124 53142 53214 53241 53412 53421 随机选取任意多个: 31452 51234 24531 42513 53124 ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值