日期:2014-05-16  浏览次数:20937 次

双色求彩票的算法,随即生成一组数,求存储过程回来研究。
rt
肯定不能百分之百对了,不然都中了。
给个类似的例子,我想看看算法。

------解决方案--------------------
这个算法主要是使用数组。再用就是生成随机数。
写过Java的可以供参考,可以修改为PL/SQL存储过程。
Java code

package net.liugeng.lottery;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.io.IOException;
import java.util.Random;
public class Main
{
    public static void main(String[] args)
    {
        // 产生几组随机数,要求一组数中不能有重复的数字
        System.out.print("请输入投注注数: ");
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        int nums = 0;
        try
        {
            nums = Integer.parseInt( br.readLine() );
        }
        catch(IOException e)
        {
            System.out.println(e.getMessage());
        }
        int[][] result;
        result = new int[nums][7];
        Random rand = new Random();
        for(int i = 0; i < nums; i ++)
        {            
            for(int j = 0; j < 6; j ++)
            {
                int newNum = rand.nextInt(33) + 1;
                while(true)
                {                    
                    boolean flag = true;                    
                    for(int k = 0; k < j; k ++)
                    {
                        if(newNum == result[i][k])
                        {
                            flag = false;
                        }
                    }
                    if(flag == true)
                    {                        
                        break;
                    }
                    newNum = rand.nextInt(33) + 1;
                }
                result[i][j] = newNum;
                
            }
            result[i][6] = rand.nextInt(16) + 1;
            
        }
        
        for(int i = 0; i < nums; i ++)
        {
            System.out.print("第" + (i+1) + "组: 红色球为: ");
            for(int j = 0; j < 6; j ++)
            {
                System.out.print(result[i][j] + " ");
            }
            System.out.print("蓝色球为: " + result[i][6]);
            System.out.println();
        }
        
        
    }

}

------解决方案--------------------
declare
type tab is table of integer index by binary_integer;
v_tab tab;
v_num int;
v_i int := 0;
v_continue boolean := false;
begin
for i in 1 .. 7 loop
v_i := v_i + 1;
v_tab(v_i) := 0;
end loop;

v_i := 0;

loop
v_num := round(dbms_random.value(1, 36));
v_continue := false;
for i in 1 .. 6 loop
if v_tab(i) = v_num then
v_continue := true;
end if;
end loop;
  
if v_continue = false then
v_i := v_i + 1;
v_tab(v_i) := v_num;
if v_i < 7 then
dbms_output.put_line('red' || v_i || '=' || v_num);
else
dbms_output.put_line('blue' || '=' || v_num);
end if;
end if;
exit when v_i = 7;
end loop;

end;