using System;
using System.Collections.Generic;
using CP.Cache;
using CP.Common;
using CP.Model;
using System.Linq;

namespace CP.Business
{
    /// <summary>
    /// 体彩大乐透逻辑操作类
    /// </summary>
    public class Tcdlt
    {


        /// <summary>
        /// 缓存
        /// </summary>
        static WMCache cache = WMCache.GetCacheService();

        #region 最近n期形态=x的数据列表

        /// <summary>
        /// 后区和值的最近n条
        /// </summary>
        /// <param name="hz"></param>
        /// <returns></returns>
        public static List<TcdltInfo> GetTcdltListByHhz(ref List<TcdltInfo> list, int hz)
        {
            List<TcdltInfo> rlist = new List<TcdltInfo>();
            if (list != null && list.Count > 0)
            {
                int size = list.Count;
                for (int i = 0; i < size; i++)
                {
                    if (list[i].hhz == hz)
                        rlist.Add(list[i]);
                }
            }
            return rlist;
        }

        /// <summary>
        /// 所有范围在shz和ehz之间的数据列表
        /// </summary>
        /// <param name="shz"></param>
        /// <param name="ehz"></param>
        /// <returns></returns>
        public static List<TcdltInfo> GetTcdltListByQHz(ref List<TcdltInfo> list, int shz, int ehz)
        {
            List<TcdltInfo> rlist = new List<TcdltInfo>();
            if (list != null && list.Count > 0)
            {
                int size = list.Count;
                for (int i = 0; i < size; i++)
                {
                    if (list[i].qhz >= shz && list[i].qhz <= ehz)
                        rlist.Add(list[i]);
                }
            }
            return rlist;
        }

        /// <summary>
        /// 所后区号=
        /// </summary>
        /// <param name="blue"></param>
        /// <returns></returns>
        public static List<TcdltInfo> GetTcdltListByHqhm(ref List<TcdltInfo> list, int blue)
        {
            List<TcdltInfo> rlist = new List<TcdltInfo>();
            if (list != null && list.Count > 0)
            {
                int size = list.Count;
                for (int i = 0; i < size; i++)
                {
                    if (list[i].n6 == blue || list[i].n7 == blue)
                        rlist.Add(list[i]);
                }
            }
            return rlist;
        }

        /// <summary>
        /// 所有号码中包括red的数据
        /// </summary>
        /// <param name="red"></param>
        /// <returns></returns>
        public static List<TcdltInfo> GetTcdltListByQqhm(ref List<TcdltInfo> list, int red)
        {
            List<TcdltInfo> rlist = new List<TcdltInfo>();
            if (list != null && list.Count > 0)
            {
                int size = list.Count;
                for (int i = 0; i < size; i++)
                {
                    List<int> kjh = new List<int>() { list[i].n1, list[i].n2, list[i].n3, list[i].n4, list[i].n5 };
                    if (kjh.Contains(red))
                        rlist.Add(list[i]);
                }
            }
            return rlist;
        }


        #endregion

        /// <summary>
        /// 根据短期数,查询大乐透历史同期号
        /// </summary>
        /// <param name="shortqi">短期数</param>
        /// <returns></returns>
        public static List<TcdltInfo> GetHistoryTcdltList(ref List<TcdltInfo> list, string shortqi)
        {
            List<TcdltInfo> rlist = new List<TcdltInfo>();
            if (list != null && list.Count > 0)
            {
                int size = list.Count;
                for (int i = 0; i < size; i++)
                {
                    if (list[i].qi.ToString().Substring(4) == shortqi)
                    {
                        rlist.Add(list[i]);
                    }
                }
            }

            return rlist;
        }

        /// <summary>
        /// 取出某个info的五分区的某个区间的个数
        /// </summary>
        /// <param name="info"></param>
        /// <param name="qj"></param>
        /// <returns></returns>
        public static int GetDlt5fqQjCount(TcdltInfo info, int qj)
        {
            List<int> kjh = new List<int> { info.n1, info.n2, info.n3, info.n4, info.n5 };
            int[] sqb = { 0, 0, 0, 0, 0 };
            for (int j = 1; j < 8; j++)
            {
                if (kjh.Contains(j))
                    sqb[0]++;
            }
            for (int j = 8; j < 15; j++)
            {
                if (kjh.Contains(j))
                    sqb[1]++;
            }
            for (int j = 15; j < 22; j++)
            {
                if (kjh.Contains(j))
                    sqb[2]++;
            }
            for (int j = 22; j < 29; j++)
            {
                if (kjh.Contains(j))
                    sqb[3]++;
            }
            for (int j = 29; j < 36; j++)
            {
                if (kjh.Contains(j))
                    sqb[4]++;
            }

            if (qj == 1)
                return sqb[0];

            if (qj == 2)
                return sqb[1];

            if (qj == 3)
                return sqb[2];

            if (qj == 4)
                return sqb[3];

            if (qj == 5)
                return sqb[4];

            return 0;
        }

        /// <summary>
        /// 取出某个info的七分区的某个区间的个数
        /// </summary>
        /// <param name="info"></param>
        /// <param name="qj"></param>
        /// <returns></returns>
        public static int GetDlt7fqQjCount(TcdltInfo info, int qj)
        {
            List<int> kjh = new List<int> { info.n1, info.n2, info.n3, info.n4, info.n5 };
            int[] sqb = { 0, 0, 0, 0, 0, 0, 0 };
            for (int j = 1; j < 6; j++)
            {
                if (kjh.Contains(j))
                    sqb[0]++;
            }
            for (int j = 6; j < 11; j++)
            {
                if (kjh.Contains(j))
                    sqb[1]++;
            }
            for (int j = 11; j < 16; j++)
            {
                if (kjh.Contains(j))
                    sqb[2]++;
            }
            for (int j = 16; j < 21; j++)
            {
                if (kjh.Contains(j))
                    sqb[3]++;
            }
            for (int j = 21; j < 26; j++)
            {
                if (kjh.Contains(j))
                    sqb[4]++;
            }
            for (int j = 26; j < 31; j++)
            {
                if (kjh.Contains(j))
                    sqb[5]++;
            }
            for (int j = 31; j < 36; j++)
            {
                if (kjh.Contains(j))
                    sqb[6]++;
            }

            if (qj == 1)
                return sqb[0];

            if (qj == 2)
                return sqb[1];

            if (qj == 3)
                return sqb[2];

            if (qj == 4)
                return sqb[3];

            if (qj == 5)
                return sqb[4];

            if (qj == 6)
                return sqb[5];

            if (qj == 7)
                return sqb[6];

            return 0;
        }

        #region 某个值/状态上一期的情况

        /// <summary>
        /// 前区5分区某个区间上一次个数为count的数据
        /// </summary>
        /// <param name="qj"></param>
        /// <param name="count"></param>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLast5fqQjCountTcdltInfo(ref List<TcdltInfo> list, int qj, int count, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                int size = list.Count;
                for (int i = rank - 2; i >= 0; i--)
                {

                    int[] sqb = { 0, 0, 0, 0, 0 };
                    List<int> kjh = new List<int> { list[i].n1, list[i].n2, list[i].n3, list[i].n4, list[i].n5 };
                    for (int j = 1; j < 8; j++)
                    {
                        if (kjh.Contains(j))
                            sqb[0]++;
                    }
                    for (int j = 8; j < 15; j++)
                    {
                        if (kjh.Contains(j))
                            sqb[1]++;
                    }
                    for (int j = 15; j < 22; j++)
                    {
                        if (kjh.Contains(j))
                            sqb[2]++;
                    }
                    for (int j = 22; j < 29; j++)
                    {
                        if (kjh.Contains(j))
                            sqb[3]++;
                    }
                    for (int j = 29; j < 36; j++)
                    {
                        if (kjh.Contains(j))
                            sqb[4]++;
                    }

                    if (qj == 1 && sqb[0] == count)
                    {
                        return list[i];
                    }
                    if (qj == 2 && sqb[1] == count)
                    {
                        return list[i];
                    }
                    if (qj == 3 && sqb[2] == count)
                    {
                        return list[i];
                    }
                    if (qj == 4 && sqb[3] == count)
                    {
                        return list[i];
                    }
                    if (qj == 5 && sqb[4] == count)
                    {
                        return list[i];
                    }
                }
            }

            return info;
        }

        /// <summary>
        /// 前区7分区某个区间上一次个数为count的数据
        /// </summary>
        /// <param name="qj"></param>
        /// <param name="count"></param>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLast7fqQjCountTcdltInfo(ref List<TcdltInfo> list, int qj, int count, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                int size = list.Count;
                for (int i = rank - 2; i >= 0; i--)
                {

                    int[] sqb = { 0, 0, 0, 0, 0, 0, 0 };
                    List<int> kjh = new List<int> { list[i].n1, list[i].n2, list[i].n3, list[i].n4, list[i].n5 };
                    for (int j = 1; j < 6; j++)
                    {
                        if (kjh.Contains(j))
                            sqb[0]++;
                    }
                    for (int j = 6; j < 11; j++)
                    {
                        if (kjh.Contains(j))
                            sqb[1]++;
                    }
                    for (int j = 11; j < 16; j++)
                    {
                        if (kjh.Contains(j))
                            sqb[2]++;
                    }
                    for (int j = 16; j < 21; j++)
                    {
                        if (kjh.Contains(j))
                            sqb[3]++;
                    }
                    for (int j = 21; j < 26; j++)
                    {
                        if (kjh.Contains(j))
                            sqb[4]++;
                    }
                    for (int j = 26; j < 31; j++)
                    {
                        if (kjh.Contains(j))
                            sqb[5]++;
                    }
                    for (int j = 31; j < 36; j++)
                    {
                        if (kjh.Contains(j))
                            sqb[6]++;
                    }

                    if (qj == 1 && sqb[0] == count)
                    {
                        return list[i];
                    }
                    if (qj == 2 && sqb[1] == count)
                    {
                        return list[i];
                    }
                    if (qj == 3 && sqb[2] == count)
                    {
                        return list[i];
                    }
                    if (qj == 4 && sqb[3] == count)
                    {
                        return list[i];
                    }
                    if (qj == 5 && sqb[4] == count)
                    {
                        return list[i];
                    }
                    if (qj == 6 && sqb[5] == count)
                    {
                        return list[i];
                    }
                    if (qj == 7 && sqb[6] == count)
                    {
                        return list[i];
                    }
                }
            }

            return info;
        }

        /// <summary>
        /// 前区上一期和尾val的数据
        /// </summary>
        /// <param name="val"></param>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLastQhwTcdltInfo(ref List<TcdltInfo> list, int val, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                for (int i = rank - 2; i >= 0; i--)
                {
                    if (ZstUtils.GetHw(list[i].qhz) == val)
                    {
                        info = list[i];
                        return info;
                    }
                }
            }
            return info;
        }

        /// <summary>
        /// 后区上一期和尾val的数据
        /// </summary>
        /// <param name="val"></param>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLastHhwTcdltInfo(ref List<TcdltInfo> list, int val, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                for (int i = rank - 2; i >= 0; i--)
                {
                    if (ZstUtils.GetHw(list[i].hhz) == val)
                    {
                        info = list[i];
                        return info;
                    }
                }
            }
            return info;
        }

        /// <summary>
        ///前区上一次和值奇偶形态的数据
        /// </summary>
        /// <param name="xt"></param>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLastQhzJoTcdltInfo(ref List<TcdltInfo> list, int xt, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                for (int i = rank - 2; i >= 0; i--)
                {
                    if (xt == 0)
                    {
                        if (list[i].qhz % 2 != 0)
                        {
                            info = list[i];
                            return info;
                        }
                    }
                    if (xt == 1)
                    {
                        if (list[i].qhz % 2 == 0)
                        {
                            info = list[i];
                            return info;
                        }
                    }
                }
            }
            return info;
        }
        /// <summary>
        /// 大乐透前区跨度奇偶 上一次
        /// </summary>
        /// <param name="xt"></param>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLastQkdJoTcdltInfo(ref List<TcdltInfo> list, int xt, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                for (int i = rank - 2; i >= 0; i--)
                {
                    if (xt == 0)
                    {
                        if (list[i].qkd % 2 != 0)
                        {
                            info = list[i];
                            return info;
                        }
                    }
                    if (xt == 1)
                    {
                        if (list[i].qkd % 2 == 0)
                        {
                            info = list[i];
                            return info;
                        }
                    }
                }
            }
            return info;
        }

        /// <summary>
        /// 大乐透前区跨度大小 前一次情况
        /// </summary>
        /// <param name="xt"></param>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLastQkdDxTcdltInfo(ref List<TcdltInfo> list, int xt, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                for (int i = rank - 2; i >= 0; i--)
                {
                    if (xt == 0)
                    {
                        if (list[i].qkd > 18)
                        {
                            info = list[i];
                            return info;
                        }
                    }
                    if (xt == 1)
                    {
                        if (list[i].qkd < 19)
                        {
                            info = list[i];
                            return info;
                        }
                    }
                }
            }
            return info;
        }


        /// <summary>
        /// 大乐透前区跨度质合 前一次情况 
        /// </summary>
        /// <param name="xt"></param>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLastQkdZhTcdltInfo(ref List<TcdltInfo> list, int xt, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                for (int i = rank - 2; i >= 0; i--)
                {
                    if (xt == 0)
                    {
                        if (ZstUtils.GetZh(list[i].qkd) == 0)
                        {
                            info = list[i];
                            return info;
                        }
                    }
                    if (xt == 1)
                    {
                        if (ZstUtils.GetZh(list[i].qkd) == 1)
                        {
                            info = list[i];
                            return info;
                        }
                    }
                }
            }
            return info;
        }

        /// <summary>
        ///后区上一次和值奇偶形态的数据
        /// </summary>
        /// <param name="xt"></param>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLastHhzJoTcdltInfo(ref List<TcdltInfo> list, int xt, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                for (int i = rank - 2; i >= 0; i--)
                {
                    if (xt == 0)
                    {
                        if (list[i].hhz % 2 != 0)
                        {
                            info = list[i];
                            return info;
                        }
                    }
                    if (xt == 1)
                    {
                        if (list[i].hhz % 2 == 0)
                        {
                            info = list[i];
                            return info;
                        }
                    }
                }
            }
            return info;
        }

        /// <summary>
        /// 前区上一次和值val的数据
        /// </summary>
        /// <param name="val"></param>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLastQhzTcdltInfo(ref List<TcdltInfo> list, int shz, int ehz, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                for (int i = rank - 2; i >= 0; i--)
                {
                    if (list[i].qhz >= shz && list[i].qhz <= ehz)
                    {
                        info = list[i];
                        return info;
                    }
                }
            }
            return info;
        }

        /// <summary>
        /// 后区上一次和值val的数据
        /// </summary>
        /// <param name="val"></param>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLastHhzTcdltInfo(ref List<TcdltInfo> list, int val, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                for (int i = rank - 2; i >= 0; i--)
                {
                    if (list[i].hhz == val)
                    {
                        info = list[i];
                        return info;
                    }
                }
            }
            return info;
        }

        /// <summary>
        /// 后和值上一次的值
        /// </summary>
        /// <param name="shz"></param>
        /// <param name="ehz"></param>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLastHhzTcdltInfo(ref List<TcdltInfo> list, int shz, int ehz, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                for (int i = rank - 2; i >= 0; i--)
                {
                    if (list[i].hhz >= shz && list[i].hhz <= ehz)
                    {
                        info = list[i];
                        return info;
                    }
                }
            }
            return info;
        }

        /// <summary>
        /// 前区上一次跨度val的数据
        /// </summary>
        /// <param name="val"></param>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLastQkdTcdltInfo(ref List<TcdltInfo> list, int val, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                for (int i = rank - 2; i >= 0; i--)
                {
                    if (list[i].qkd == val)
                    {
                        info = list[i];
                        return info;
                    }
                }
            }
            return info;
        }

        /// <summary>
        /// 取出个排名的上一次数据
        /// </summary>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLastTcdltInfo(ref List<TcdltInfo> list, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                for (int i = rank - 2; i >= 0; i--)
                {
                    if (list[i].rank == rank - 1)
                    {
                        info = list[i];
                        return info;
                    }
                }
            }
            return info;
        }

        /// <summary>
        /// 取出个排名的下一次数据
        /// </summary>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetNextTcdltInfo(ref List<TcdltInfo> list, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                for (int i = rank - 1; i < list.Count; i++)
                {
                    if (list[i].rank == rank + 1)
                    {
                        info = list[i];
                        return info;
                    }
                }
            }
            return info;
        }

        /// <summary>
        /// 上一次AC值012路的情况
        /// </summary>
        /// <param name="val"></param>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLastAc012TcdltInfo(ref List<TcdltInfo> list, int val, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                int size = list.Count;
                for (int i = rank - 2; i >= 0; i--)
                {
                    if (list[i].ac % 3 == val)
                    {
                        info = list[i];
                        return info;
                    }
                }
            }

            return info;
        }

        /// <summary>
        /// 上一期AC值的质合情况
        /// </summary>
        /// <param name="xt"></param>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLastAcZhTcdltInfo(ref List<TcdltInfo> list, int xt, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                List<int> zh = new List<int> { 4, 6, 8, 9, 10 };
                int size = list.Count;
                for (int i = rank - 2; i >= 0; i--)
                {
                    if (xt == 0)
                    {
                        if (!zh.Contains(list[i].ac))
                        {
                            info = list[i];
                            return info;
                        }
                    }
                    if (xt == 1)
                    {
                        if (zh.Contains(list[i].ac))
                        {
                            info = list[i];
                            return info;
                        }
                    }
                }
            }

            return info;
        }

        /// <summary>
        /// 上一期AC值的大小情况
        /// </summary>
        /// <param name="xt"></param>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLastAcDxTcdltInfo(ref List<TcdltInfo> list, int xt, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                int size = list.Count;
                for (int i = rank - 2; i >= 0; i--)
                {
                    if (xt == 0)
                    {
                        if (list[i].ac > 5)
                        {
                            info = list[i];
                            return info;
                        }
                    }
                    if (xt == 1)
                    {
                        if (list[i].ac < 6)
                        {
                            info = list[i];
                            return info;
                        }
                    }
                }
            }

            return info;
        }

        /// <summary>
        /// 上一期某个AC值大小的数据
        /// </summary>
        /// <param name="xt"></param>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLastAcJoTcdltInfo(ref List<TcdltInfo> list, int xt, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                int size = list.Count;
                for (int i = rank - 2; i >= 0; i--)
                {
                    if (xt == 0)
                    {
                        if (list[i].ac % 2 != 0)
                        {
                            info = list[i];
                            return info;
                        }
                    }
                    if (xt == 1)
                    {
                        if (list[i].ac % 2 == 0)
                        {
                            info = list[i];
                            return info;
                        }
                    }
                }
            }

            return info;
        }

        /// <summary>
        /// 上一期某个AC值的数据
        /// </summary>
        /// <param name="val"></param>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLastAcTcdltInfo(ref List<TcdltInfo> list, int val, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                int size = list.Count;
                for (int i = rank - 2; i >= 0; i--)
                {
                    if (list[i].ac == val)
                    {
                        info = list[i];
                        return info;
                    }
                }
            }

            return info;
        }

        /// <summary>
        /// 上一期某个后区号的冷热情况.
        /// </summary>
        /// <param name="xt"></param>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLastHqHotTcdltInfo(ref List<TcdltInfo> list, int xt, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                int size = list.Count;
                for (int i = rank - 2; i >= 0; i--)
                {
                    List<int> hot = Tcdlt.GetTcdltHqHotList(ref list,list[i].rank, 16);
                    if (xt == 0)
                    {
                        if (!hot.Contains(list[i].n6) || !hot.Contains(list[i].n7))
                        {
                            info = list[i];
                            return info;
                        }
                    }
                    if (xt == 1)
                    {
                        if (hot.Contains(list[i].n6) || !hot.Contains(list[i].n7))
                        {
                            info = list[i];
                            return info;
                        }
                    }
                }
            }

            return info;
        }

        /// <summary>
        /// 根据当前出号和排名,查询出上一次出此号时的数据
        /// 主要用在遗漏上
        /// </summary>
        /// <param name="val"></param>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLastHqTcdltInfo(ref List<TcdltInfo> list, int val, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                int size = list.Count;
                for (int i = rank - 2; i >= 0; i--)
                {
                    if (list[i].n6 == val || list[i].n7 == val)
                    {
                        info = list[i];
                        return info;
                    }
                }
            }
            return info;
        }



        /// <summary>
        /// 前区
        /// 根据当前出号和排名,查询出上一次出此号时的数据
        /// 主要用在遗漏上
        /// </summary>
        /// <param name="val"></param>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLastQqTcdltInfo(ref List<TcdltInfo> list, int val, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                int size = list.Count;
                for (int i = rank - 2; i >= 0; i--)
                {
                    List<int> kjh = new List<int> { list[i].n1, list[i].n2, list[i].n3, list[i].n4, list[i].n5 };
                    if (kjh.Contains(val))
                    {
                        info = list[i];
                        return info;
                    }
                }
            }

            return info;
        }

        /// <summary>
        /// 后区跨度上一期情况 
        /// </summary>
        /// <param name="val"></param>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLastHqKdTcdltInfo(ref List<TcdltInfo> list, int val, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                int size = list.Count;
                for (int i = rank - 2; i >= 0; i--)
                {
                    if (Math.Abs(list[i].n7 - list[i].n6) == val)
                    {
                        info = list[i];
                        return info;
                    }
                }
            }
            return info;
        }

        /// <summary>
        /// 后区大小形态上一期情况 
        /// </summary>
        /// <param name="val"></param>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLastHqDxTcdltInfo(ref List<TcdltInfo> list, string dx, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                int size = list.Count;
                for (int i = rank - 2; i >= 0; i--)
                {
                    if (ZstUtils.GetDltHqDxxt(list[i].n6, list[i].n7).Equals(dx))
                    {
                        info = list[i];
                        return info;
                    }
                }
            }
            return info;
        }

        /// <summary>
        /// 后区奇偶形态上一期情况 
        /// </summary>
        /// <param name="val"></param>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLastHqJoTcdltInfo(ref List<TcdltInfo> list, string jo, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                int size = list.Count;
                for (int i = rank - 2; i >= 0; i--)
                {
                    if (ZstUtils.GetDltHqJoxt(list[i].n6, list[i].n7).Equals(jo))
                    {
                        info = list[i];
                        return info;
                    }
                }
            }
            return info;
        }


        /// <summary>
        /// 后区冷热形态上一期情况 
        /// </summary>
        /// <param name="val"></param>
        /// <param name="rank"></param>
        /// <returns></returns>
        public static TcdltInfo GetLastHqLrTcdltInfo(ref List<TcdltInfo> list, string lr, int rank)
        {
            TcdltInfo info = new TcdltInfo();
            if (list != null && list.Count > 0)
            {
                int size = list.Count;
                for (int i = rank - 2; i >= 0; i--)
                {
                    if (Getlrxt(ref list, list[i]).Equals(lr))
                    {
                        info = list[i];
                        return info;
                    }
                }
            }
            return info;
        }

        #region 后区冷热
        /// <summary>
        /// 后区冷热形态
        /// </summary>
        /// <param name="info"></param>
        /// <returns></returns>
        public static string Getlrxt(ref List<TcdltInfo> list, TcdltInfo info)
        {
            List<int> hot = Tcdlt.GetTcdltHqHotList(ref list,info.rank, 6);
            string n6lr = "冷";
            string n7lr = "冷";
            if (hot.Contains(info.n6))
                n6lr = "热";
            if (hot.Contains(info.n7))
                n7lr = "热";
            return (n6lr + n7lr).ToString().Trim();

        }
        #endregion

        #endregion

        #region 冷热号
        /// <summary>
        /// 某期大乐透前N期的数据
        /// 用于计算大乐透前区冷热号
        /// </summary>
        /// <param name="rank">当前期的排名</param>
        /// <param name="pagesize">前n期</param>
        /// <returns></returns>
        public static List<int> GetTcdltQqHotList(ref List<TcdltInfo> list, int rank, int pagesize)
        {
            List<int> rlist = new List<int>();
            if (list != null && list.Count > 0)
            {
                int size = list.Count;
                for (int i = rank - 2; i >= (rank - pagesize - 1) && i >= 0; i--)
                {
                    rlist.Add(list[i].n1);
                    rlist.Add(list[i].n2);
                    rlist.Add(list[i].n3);
                    rlist.Add(list[i].n4);
                    rlist.Add(list[i].n5);
                }
            }

            return rlist;
        }

        /// <summary>
        /// 最近N期的前区热号...
        /// </summary>
        /// <param name="pagesize"></param>
        /// <returns></returns>
        public static List<int> GetTcdltQhHotList(ref List<TcdltInfo> list, int pagesize)
        {
            List<int> rlist = new List<int>();
            if (list != null && list.Count > 0)
            {
                int size = list.Count;
                for (int i = size - 1; i >= (size - pagesize - 1) && i >= 0; i--)
                {
                    rlist.Add(list[i].n1);
                    rlist.Add(list[i].n2);
                    rlist.Add(list[i].n3);
                    rlist.Add(list[i].n4);
                    rlist.Add(list[i].n5);
                }
            }

            return rlist;
        }

        /// <summary>
        /// 某期大乐透前n期的数据
        /// 用于计算大乐透后区冷热号
        /// </summary>
        /// <param name="rank">当前期的排名</param>
        /// <param name="pagesize">前n期</param>
        /// <returns></returns>
        public static List<int> GetTcdltHqHotList(ref List<TcdltInfo> list, int rank, int pagesize)
        {
            List<int> rlist = new List<int>();
            if (list != null && list.Count > 0)
            {
                int size = list.Count;

                for (int i = rank - 2; i >= (rank - pagesize - 1) && i >= 0; i--)
                {
                    rlist.Add(list[i].n6);
                    rlist.Add(list[i].n7);
                }
            }

            return rlist;
        }

        /// <summary>
        /// 近n期的大乐透后区热号
        /// </summary>
        /// <param name="pagesize"></param>
        /// <returns></returns>
        public static List<int> GetTcdltHqHotList(ref List<TcdltInfo> list, int pagesize)
        {
            List<int> rlist = new List<int>();
            if (list != null && list.Count > 0)
            {
                int size = list.Count;

                for (int i = size - 1; i >= (size - pagesize - 1) && i >= 0; i--)
                {
                    rlist.Add(list[i].n6);
                    rlist.Add(list[i].n7);
                }
            }

            return rlist;
        }


        #endregion

        #region 获取数据
        /// <summary>
        /// 取某一期的数据
        /// 根据期数值
        /// </summary>
        /// <param name="qi"></param>
        /// <returns></returns>
        public static TcdltInfo GetTcdltInfo(ref List<TcdltInfo> list, int qi)
        {
            TcdltInfo info = new TcdltInfo();
            int size = list.Count;
            for (int i = 0; i < size; i++)
            {
                if (list[i].qi == qi)
                {
                    info = list[i];
                    break;
                }
            }
            return info;
        }

        /// <summary>
        /// 大乐透星期x的所有数据列表
        /// </summary>
        /// <param name="week"></param>
        /// <returns></returns>
        public static List<TcdltInfo> GetTcdltWeekList(ref List<TcdltInfo> list, int week)
        {
            List<TcdltInfo> rlist = new List<TcdltInfo>();
            if (list != null && list.Count > 0)
            {
                int size = list.Count;
                for (int i = 0; i < size; i++)
                {
                    if (list[i].week == week)
                        rlist.Add(list[i]);
                }
            }
            return rlist;
        }

        /// <summary>
        /// 走势图上的最近xx期数据.
        /// </summary>
        /// <param name="pagesize">最近n条</param>
        /// <param name="year">按年份</param>
        /// <param name="sqi">开始期</param>
        /// <param name="eqi">结束期</param>
        /// <param name="week">星期x</param>
        /// <returns></returns>
        public static List<TcdltInfo> GetTcdltList(ref List<TcdltInfo> datalist, int pagesize, int year, int sqi, int eqi, int week = 0)
        {
            var list = new List<TcdltInfo>();
            ///星期x的条件时
            ///数据来源不一样.
            if (week > 0)
                list = GetTcdltWeekList(ref datalist,week);
            else
                list = datalist;

            List<TcdltInfo> rlist = new List<TcdltInfo>();
            if (list != null && list.Count > 0)
            {
                int size = list.Count;
                if (pagesize > 0)
                {
                    for (int i = (size - pagesize); i < size; i++)
                    {
                        rlist.Add(list[i]);
                    }
                    return rlist;
                }
                if (year > 0)
                {
                    rlist.Clear();
                    for (int i = 0; i < size; i++)
                    {
                        if (TypeConverter.StrToInt(list[i].qi.ToString().Substring(0, 4), 0) == year)
                            rlist.Add(list[i]);
                    }
                    return rlist;
                }
                if (sqi > 0 && eqi > 0)
                {
                    rlist.Clear();
                    int srank = GetTcdltInfo(ref list,sqi).rank;
                    int erank = GetTcdltInfo(ref list,eqi).rank;
                    if (erank != 0 && srank != 0 && erank > srank)
                    {
                        rlist.AddRange(list.Where(m => m.rank >= srank && m.rank <= erank));
                        //for (int i = srank - 1; i < erank && i < size; i++)
                        //{
                        //    rlist.Add(list[i]);
                        //}
                    }
                    return rlist;
                }
                if (week > 0)
                    return list;
                if (pagesize == 0 && year == 0 && eqi == 0 && sqi == 0 && week == 0)
                    return list;
            }
            return rlist;
        }

        /// <summary>
        /// 走势图上的最近xx期数据.
        /// </summary>
        /// <param name="pagesize">最近n条</param>
        /// <param name="sqi">开始期</param>
        /// <param name="eqi">结束期</param>
        /// <param name="year">按年份</param>
        /// <param name="qhws">期号尾数</param>
        /// <param name="week">星期x</param>
        /// <param name="month">按月份</param>
        /// <param name="tq">同期</param>
        /// <returns></returns>
        public static List<TcdltInfo> GetTcdltList(ref List<TcdltInfo> datalist, int pagesize, int sqi, int eqi, int year, int month, int qhws, int week, int tq)
        {
            
            //星期x的条件时
            //数据来源不一样.
            if (week > 0)
            {
                return GetTcdltWeekList(ref datalist, week);
            }

            var list = datalist;
            List<TcdltInfo> rlist = new List<TcdltInfo>();
            int size = list.Count;
            if (pagesize > 0)
            {
                for (int i = (size - pagesize); i < size; i++)
                {
                    rlist.Add(list[i]);
                }
                return rlist;
            }
            if (tq > 0)
            {
                rlist.Clear();
                for (int i = 0; i < size; i++)
                {
                    if (TypeConverter.StrToInt(list[i].qi.ToString().Substring(4), 0) ==
                        TypeConverter.StrToInt(tq.ToString().Substring(4), 0))
                        rlist.Add(list[i]);
                }
                return rlist;
            }
            if (year > 0)
            {
                rlist.Clear();
                if (month > 0)
                {
                    if (qhws < 10)
                    {
                        for (int i = 0; i < size; i++)
                        {
                            if (list[i].date.Year == year && list[i].date.Month == month &&
                                TypeConverter.StrToInt(list[i].qi.ToString().Substring(list[i].qi.ToString().Length-1), 0) == qhws)
                                rlist.Add(list[i]);
                        }
                    }
                    else
                    {
                        for (int i = 0; i < size; i++)
                        {
                            if (list[i].date.Year == year && list[i].date.Month == month)
                                rlist.Add(list[i]);
                        }
                    }
                }
                else if (qhws < 10)
                {
                    for (int i = 0; i < size; i++)
                    {
                        if (list[i].date.Year == year &&
                            TypeConverter.StrToInt(list[i].qi.ToString().Substring(list[i].qi.ToString().Length - 1), 0) == qhws)
                            rlist.Add(list[i]);
                    }
                }
                else
                {
                    for (int i = 0; i < size; i++)
                    {
                        if (list[i].date.Year == year)
                            rlist.Add(list[i]);
                    }
                }
                return rlist;
            }
            if (month > 0)
            {
                rlist.Clear();
                if (qhws < 10)
                {
                    for (int i = 0; i < size; i++)
                    {
                        if (list[i].date.Month == month &&
                            TypeConverter.StrToInt(list[i].qi.ToString().Substring(list[i].qi.ToString().Length - 1), 0) == qhws)
                            rlist.Add(list[i]);
                    }
                }
                else
                {
                    for (int i = 0; i < size; i++)
                    {
                        if (list[i].date.Month == month)
                            rlist.Add(list[i]);
                    }
                }
                return rlist;
            }
            if (qhws < 10)
            {
                rlist.Clear();
                for (int i = 0; i < size; i++)
                {
                    if (TypeConverter.StrToInt(list[i].qi.ToString().Substring(list[i].qi.ToString().Length - 1), 0) == qhws)
                        rlist.Add(list[i]);
                }
                return rlist;
            }
            if (sqi > 0 && eqi > 0)
            {
                rlist.Clear();
                int srank = GetTcdltInfo(ref list, sqi).rank;
                int erank = GetTcdltInfo(ref list, eqi).rank;
                if (erank != 0 && srank != 0 && erank > srank)
                {
                    for (int i = srank - 1; i < erank && i < size; i++)
                    {
                        rlist.Add(list[i]);
                    }
                }
                return rlist;
            }
            return rlist;
        }

        /// <summary>
        /// 大乐透数据..
        /// 遗漏表上用到的..
        /// </summary>
        /// <param name="eqi"></param>
        /// <returns></returns>
        public static List<TcdltInfo> GetMissTcdltList(ref List<TcdltInfo> list, int eqi)
        {
            List<TcdltInfo> rlist = new List<TcdltInfo>();

            if (eqi > 0)
            {
                int size = list.Count;
                int erank = GetTcdltInfo(ref list,eqi).rank;
                if (erank > 0)
                {
                    for (int i = 0; i < erank && i < size; i++)
                    {
                        rlist.Add(list[i]);
                    }
                }
                else
                {
                    for (int i = 0; i < size; i++)
                    {
                        rlist.Add(list[i]);
                    }
                }
            }
            else
            {
                rlist = list;
            }

            return rlist;
        }

        /// <summary>
        /// 所有大乐透数据
        /// </summary>
        /// <returns></returns>
        public static List<TcdltInfo> GetTcdltList()
        {
            string key = string.Format(CacheKeys.TCDLT_DATALIST);
            List<TcdltInfo> list = cache.GetObject<List<TcdltInfo>>(key);
            if (list == null)
            {
                list = TcdltData.GetTcdltList();
                cache.AddObject(key, list, (int)CacheTime.Data);
            }
            return list;
        }

        #endregion

        #region 开奖公告相关方法

        /// <summary>
        /// 包括开机号的
        /// </summary>
        /// <param name="pagesize"></param>
        /// <returns></returns>
        public static List<TcdltLongInfo> GetTcdltKjihList(int pagesize)
        {
            //GetTcdltKjihList
            string key = string.Format(CacheKeys.TCDLT_KJH_DATA + "-{0}-kjih", pagesize);
            List<TcdltLongInfo> list = cache.GetObject<List<TcdltLongInfo>>(key);
            if (list == null)
            {
                list = TcdltData.GetTcdltKjihList(pagesize);
                cache.AddObject(key, list, (int)CacheTime.Kjh);
            }
            return list;
        }

        /// <summary>
        /// 大乐透最近30期开奖数据,完整开奖信息,有缓存
        /// </summary>
        /// <returns></returns>
        public static List<TcdltLongInfo> GetTcdltListTop30(int pagesize=30)
        {
            string key = string.Format(CacheKeys.TCDLT_KJH_DATA+"-{0}",pagesize);
            List<TcdltLongInfo> list = cache.GetObject<List<TcdltLongInfo>>(key);
            if (list == null)
            {
                list = TcdltData.GetTcdltTop30(pagesize);
                cache.AddObject(key, list, (int)CacheTime.Kjh);
            }
            return list;
        }

        /// <summary>
        /// 获取最新一期开奖信息,完整开奖信息,有缓存
        /// </summary>
        /// <returns></returns>
        public static TcdltLongInfo GetTcdltInfoTop1(ref List<TcdltLongInfo> list)
        {
            TcdltLongInfo info = new TcdltLongInfo();
            //List<TcdltLongInfo> list = GetTcdltListTop30();
            if (list.Count > 0)
            {
                info = list[0];
            }
            return info;
        }

        /// <summary>
        /// 根据期数返回某期完整开奖信息,无缓存
        /// </summary>
        /// <param name="qi"></param>
        /// <returns></returns>
        public static TcdltLongInfo GetTcdltInfoByqi(int qi)
        {
            return TcdltData.GetTcdltInfoByQi(qi);
        }

        /// <summary>
        /// 返回某年对应的期数列表,有缓存
        /// </summary>
        /// <param name="year"></param>
        /// <returns></returns>
        public static List<int> GetTcdltQiListByYear(int year)
        {
            string key = string.Format(CacheKeys.TCDLT_KJH_DATA + "/qilistbyyear/{0}", year);
            List<int> list = cache.GetObject<List<int>>(key);
            if (list == null)
            {
                list = TcdltData.GetTcdltQiListByYear(year);
                cache.AddObject(key, list, (int)CacheTime.System);
            }
            return list;
        }


        #endregion

        //end
    }
}