Exemplo n.º 1
0
        public virtual bool Matched(ExpectList <T> el, out int MatchCnt, bool getRev)
        {
            //ExpectData data = el.LastData;
            string[] strArr = ChanceCode.Split('+');
            MatchCnt = 0;
            int begid = -1;   //默认为0,多期再去寻找起点

            if (el.Count > 1) //多期考虑
            {
                if (long.Parse(this.ExpectCode) < long.Parse(el.FirstData.Expect))
                {
                    Log("错误", "匹配是否需要关闭错误", "需要关闭的机会早于数据以前,无论是否中奖,立即关闭!");
                    return(true);
                }
                begid = el.IndexOf(this.ExpectCode);
                if (begid < 0)
                {
                    Log("错误", "匹配是否需要关闭错误", "需要关闭的机会不在数据中,无论是否中奖,立即关闭!");
                    return(true);
                }
            }
            //////ExpectData inputEd = el[begid];
            //////Log("计算服务", "获取到期号信息", string.Format("expect:{0};openCode:{1}",inputEd.Expect,inputEd.OpenCode));
            for (int ei = begid + 1; ei < el.Count; ei++)
            {
                ExpectData <T> data = el[ei];
                for (int k = 0; k < strArr.Length; k++)
                {
                    //Log("计算服务", string.Format("循环检查进入期数后的期数是否命中机会:{0}", ChanceCode), string.Format("expect:{0};openCode:{1}", data.Expect, data.OpenCode));
                    string   UseCode = getRev ? getRevChance(strArr[k]) : strArr[k];
                    string[] arr     = UseCode.Trim().Split('/');
                    string   strSer  = arr[0].Trim();
                    string   strCar  = arr[1].Trim();
                    for (int i = 0; i < strSer.Length; i++)
                    {
                        string strSerNo = strSer.Substring(i, 1).Trim();
                        int    iNo      = int.Parse(strSerNo);
                        if (iNo == 0)
                        {
                            iNo = 10;
                        }
                        for (int j = 0; j < strCar.Length; j++)
                        {
                            string strCarNo = strCar.Substring(j, 1).Trim();
                            if (strCarNo == data.ValueList[iNo - 1])
                            {
                                MatchCnt++;
                            }
                        }
                    }
                }
                if (MatchCnt > 0)//任何一期命中都需要关闭
                {
                    break;
                }
            }
            if (MatchCnt > 0)
            {
                return(true);
            }
            return(false);
        }
Exemplo n.º 2
0
        public override bool Matched(ExpectList <TimeSerialData> el, out int MatchCnt, bool getRev)
        {
            //ExpectData data = el.LastData;
            if (ChanceCode == null)//停止
            {
                MatchCnt = 0;
                return(true);
            }
            string[] strArr = ChanceCode.Split('+');
            MatchCnt = 0;
            int begid = -1;   //默认为0,多期再去寻找起点

            if (el.Count > 1) //多期考虑
            {
                if (long.Parse(this.ExpectCode) < long.Parse(el.FirstData.Expect))
                {
                    Log("错误", "匹配是否需要关闭错误", "需要关闭的机会早于数据以前,无论是否中奖,立即关闭!");
                    return(true);
                }
                begid = el.IndexOf(this.ExpectCode);
                if (begid < 0)
                {
                    Log("错误", "匹配是否需要关闭错误", "需要关闭的机会不在数据中,无论是否中奖,立即关闭!");
                    return(true);
                }
            }
            //////ExpectData inputEd = el[begid];
            //////Log("计算服务", "获取到期号信息", string.Format("expect:{0};openCode:{1}",inputEd.Expect,inputEd.OpenCode));
            if (el.Count == 1)//只匹配一期
            {
                int ei = el.Count == 1?el.Count - 1:begid + 1;
                ExpectData <TimeSerialData> data = el[ei];
                return(Match(data, out MatchCnt));

                string[] strOrgArr = data.OpenCode.Split(',');
                string   strRes    = CombinGenerator.ResortNumString(data.OpenCode, ",");
                foreach (ChanceItem ci in this.SubItems)
                {
                    CombinClass container = null;
                    string[]    strCiArr  = null;
                    if (ci.betChipCnt <= SelectNums)
                    {
                        strCiArr = new string[ci.betChipCnt];
                        Array.Copy(strOrgArr, strCiArr, ci.betChipCnt);
                    }
                    switch (ci.betType)
                    {
                    case CombinBetType.Permut:
                    {
                        if (string.Join(",", strCiArr) == ci.betCode)       //未排序的数组和投注串完全相等
                        {
                            if (this.PermutTypebaseodds.ContainsKey(ci.betChipCnt - 1))
                            {
                                MatchCnt += PermutTypebaseodds[ci.betChipCnt - 1];
                                //break;
                            }
                            else        //找不到,返回基本倍数
                            {
                                MatchCnt += 2;
                            }
                        }

                        break;
                    }

                    case CombinBetType.Combin:
                    {
                        string[] strSArr = CombinGenerator.ResortNumString(strCiArr);                      // 获取前N位排序好的中奖号码
                        if (string.Join(",", strSArr) == CombinGenerator.ResortNumString(ci.betCode, ",")) //如果排序好的前N位中奖串等于重排后的投注串,命中
                        {
                            if (this.CombinTypeChipsBaseOdds.ContainsKey(ci.betChipCnt - 1))
                            {
                                MatchCnt += CombinTypeChipsBaseOdds[ci.betChipCnt - 1];
                                //break;
                            }
                            else        //找不到,返回基本倍数
                            {
                                MatchCnt += 2;
                            }
                        }
                        break;
                    }

                    case CombinBetType.All:
                    default:
                    {
                        int tn = ci.betChipCnt + 1;                              //一定要加1,是标志基础
                        if (ci.betChipCnt > SelectNums)                          //如果大于选择码
                        {
                            container = new CombinClass(ci.betCode, SelectNums); //找出N码选出数目的所有组合
                            if (container.Contains(strRes))                      //命中
                            {
                                if (this.AllTypeChipsBaseOdds.ContainsKey(tn))
                                {
                                    MatchCnt += AllTypeChipsBaseOdds[tn];
                                    //break;
                                }
                                else        //找不到,返回基本倍数
                                {
                                    MatchCnt += 2;
                                }
                            }
                        }
                        else
                        {
                            container = new CombinClass(strRes, ci.betChipCnt);        //中奖结果的C(S,N)组合
                            if (container.Contains(ci.betCode))
                            {
                                if (this.AllTypeChipsBaseOdds.ContainsKey(tn))
                                {
                                    MatchCnt += AllTypeChipsBaseOdds[tn];
                                    //break;
                                }
                                else        //找不到,返回基本倍数
                                {
                                    MatchCnt += 2;
                                }
                            }
                        }
                        break;
                    }
                    }
                    if (ci.betChipCnt >= SelectNums && MatchCnt > 0)//只要有一个子长机会命中,就不再检查其他子机会
                    {
                        break;
                    }
                }
            }
            else
            {
                for (int i = begid + 1; i < el.Count; i++)//中途任何一次匹配都干掉
                {
                    ExpectData <TimeSerialData> data = el[i];
                    bool suc = Match(data, out MatchCnt);
                    if (suc)
                    {
                        break;
                    }
                }
            }
            if (MatchCnt > 0)
            {
                return(true);
            }
            return(false);
        }