12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535 |
- using System;
- using System.Collections.Generic;
- using CP.Cache;
- using CP.Common;
- using CP.Model;
- using System.Linq;
- namespace CP.Business
- {
- /// <summary>
- /// 福彩双色球逻辑操作类
- /// sam
- /// </summary>
- public class Fcssq
- {
- /// <summary>
- /// 缓存
- /// </summary>
- static WMCache cache = WMCache.GetCacheService();
- #region 尾数分布
- /// <summary>
- /// 上一期尾数的数据
- /// </summary>
- /// <param name="val"></param>
- /// <param name="rank"></param>
- /// <returns></returns>
- public static FcssqInfo GetWsFcssqInfo(ref List<FcssqInfo> list, int val, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- if (list != null && list.Count > 0)
- {
- for (int i = rank - 2; i >= 0; i--)
- {
- int[] ws = { list[i].n1 % 10, list[i].n2 % 10, list[i].n3 % 10, list[i].n4 % 10, list[i].n5 % 10, list[i].n6 % 10 };
- if (ws.Contains(val))
- {
- info = list[i];
- return info;
- }
- }
- }
- return info;
- }
- /// <summary>
- /// 上一期尾数的数据
- /// </summary>
- /// <param name="val"></param>
- /// <param name="rank"></param>
- /// <returns></returns>
- public static FcssqInfo GetWsfbFcssqInfo(ref List<FcssqInfo> list, int val, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- if (list != null && list.Count > 0)
- {
- 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, list[i].n6 };
- if (kjh.Contains(val))
- {
- info = list[i];
- return info;
- }
- }
- }
- return info;
- }
- #endregion
- #region 最近n期形态=x的数据列表
- /// <summary>
- /// 所有范围在shz和ehz之间的数据列表
- /// </summary>
- /// <param name="shz"></param>
- /// <param name="ehz"></param>
- /// <returns></returns>
- public static List<FcssqInfo> GetFcssqListByHz(ref List<FcssqInfo> list,int shz, int ehz)
- {
- List<FcssqInfo> rlist = new List<FcssqInfo>();
- if (list != null && list.Count > 0)
- {
- int size = list.Count;
- for (int i = 0; i < size; i++)
- {
- if (list[i].hz >= shz && list[i].hz <= ehz)
- rlist.Add(list[i]);
- }
- }
- return rlist;
- }
- /// <summary>
- /// 所有蓝号=blue的数据
- /// </summary>
- /// <param name="blue"></param>
- /// <returns></returns>
- public static List<FcssqInfo> GetFcssqListByBlue(ref List<FcssqInfo> list, int blue)
- {
- List<FcssqInfo> rlist = new List<FcssqInfo>();
- if (list != null && list.Count > 0)
- {
- int size = list.Count;
- for (int i = 0; i < size; i++)
- {
- if (list[i].n7 == blue)
- rlist.Add(list[i]);
- }
- }
- return rlist;
- }
- /// <summary>
- /// 所有红球中包括 red的数据
- /// </summary>
- /// <param name="red"></param>
- /// <returns></returns>
- public static List<FcssqInfo> GetFcssqListByRed(ref List<FcssqInfo> list,int red)
- {
- List<FcssqInfo> rlist = new List<FcssqInfo>();
- 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, list[i].n6 };
- if (kjh.Contains(red))
- rlist.Add(list[i]);
- }
- }
- return rlist;
- }
- #endregion
- #region 取出某个info的某个区间的个数
- /// <summary>
- /// 取出某个info的某个区间的个数
- /// </summary>
- /// <param name="info"></param>
- /// <param name="qj"></param>
- /// <returns></returns>
- public static int GetSsqRedQjCount(FcssqInfo info, int qj)
- {
- List<int> kjh = new List<int> { info.n1, info.n2, info.n3, info.n4, info.n5, info.n6 };
- int[] sqb = { 0, 0, 0 };
- for (int j = 1; j < 12; j++)
- {
- if (kjh.Contains(j))
- sqb[0]++;
- }
- for (int j = 12; j < 23; j++)
- {
- if (kjh.Contains(j))
- sqb[1]++;
- }
- for (int j = 23; j < 34; j++)
- {
- if (kjh.Contains(j))
- sqb[2]++;
- }
- if (qj == 1)
- return sqb[0];
- if (qj == 2)
- return sqb[1];
- if (qj == 3)
- return sqb[2];
- return 0;
- }
- #endregion
- #region 某个值/状态上一期的情况
- /// <summary>
- /// 红球某个区间上一次个数为count的数据
- /// </summary>
- /// <param name="qj"></param>
- /// <param name="count"></param>
- /// <param name="rank"></param>
- /// <returns></returns>
- public static FcssqInfo GetLastQjCountFcssqInfo(ref List<FcssqInfo> list,int qj, int count, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- if (list != null && list.Count > 0)
- {
- int size = list.Count;
- for (int i = rank - 2; i >= 0; i--)
- {
- int[] sqb = { 0, 0, 0 };
- List<int> kjh = new List<int> { list[i].n1, list[i].n2, list[i].n3, list[i].n4, list[i].n5, list[i].n6 };
- for (int j = 1; j < 12; j++)
- {
- if (kjh.Contains(j))
- sqb[0]++;
- }
- for (int j = 12; j < 23; j++)
- {
- if (kjh.Contains(j))
- sqb[1]++;
- }
- for (int j = 23; j < 34; j++)
- {
- if (kjh.Contains(j))
- sqb[2]++;
- }
- 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];
- }
- }
- }
- return info;
- }
- /// <summary>
- /// 某个红球(红1 2 3 4 5 6)五行状态的上一次数据
- /// </summary>
- /// <param name="redsite"></param>
- /// <param name="rank"></param>
- /// <returns></returns>
- public static FcssqInfo GetLastWxFcssqInfo(ref List<FcssqInfo> list,int redsite, int val, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- if (list != null && list.Count > 0)
- {
- //五行分布
- List<int> xj = new List<int> { 9, 10, 21, 22, 33 };
- List<int> xm = new List<int> { 3, 4, 15, 16, 27, 28 };
- List<int> xs = new List<int> { 1, 12, 13, 24, 25 };
- List<int> xh = new List<int> { 6, 7, 18, 19, 30, 31 };
- List<int> xt = new List<int> { 2, 5, 8, 11, 14, 17, 20, 23, 26, 29, 32 };
- for (int i = rank - 2; i >= 0; i--)
- {
- List<int> red = new List<int> { list[i].n1, list[i].n2, list[i].n3, list[i].n4, list[i].n5, list[i].n6 };
- for (int j = 0; j < 6; j++)
- {
- if (xj.Contains(red[redsite]) && val == 0)
- return list[i];
- if (xm.Contains(red[redsite]) && val == 1)
- return list[i];
- if (xs.Contains(red[redsite]) && val == 2)
- return list[i];
- if (xh.Contains(red[redsite]) && val == 3)
- return list[i];
- if (xt.Contains(red[redsite]) && val == 4)
- return list[i];
- }
- }
- }
- return info;
- }
- #region 和尾相关
- /// <summary>
- /// 上一其和尾val的数据
- /// </summary>
- /// <param name="val"></param>
- /// <param name="rank"></param>
- /// <returns></returns>
- public static FcssqInfo GetLastHwFcssqInfo(ref List<FcssqInfo> list,int val, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- if (list != null && list.Count > 0)
- {
- for (int i = rank - 2; i >= 0; i--)
- {
- if (list[i].hw == val)
- {
- info = list[i];
- return info;
- }
- }
- }
- return info;
- }
- /// <summary>
- /// 上一次和尾奇偶形态的数据
- /// </summary>
- /// <param name="xt"></param>
- /// <param name="rank"></param>
- /// <returns></returns>
- public static FcssqInfo GetLastHwJoFcssqInfo(ref List<FcssqInfo> list,int xt, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- if (list != null && list.Count > 0)
- {
- for (int i = rank - 2; i >= 0; i--)
- {
- if (xt == 0)
- {
- if (list[i].hw % 2 != 0)
- {
- info = list[i];
- return info;
- }
- }
- if (xt == 1)
- {
- if (list[i].hw % 2 == 0)
- {
- info = list[i];
- return info;
- }
- }
- }
- }
- return info;
- }
- /// <summary>
- /// 上一次和尾为大/小形态的数据
- /// </summary>
- /// <param name="xt">0=小;1=大</param>
- /// <param name="rank"></param>
- /// <returns></returns>
- public static FcssqInfo GetLastHwDxFcssqInfo(ref List<FcssqInfo> list,int xt, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- int size = list.Count;
- for (int i = rank - 2; i >= 0; i--)
- {
- if (xt == 0)
- {
- if (list[i].hw < 5)
- {
- info = list[i];
- return info;
- }
- }
- if (xt == 1)
- {
- if (list[i].hw > 4)
- {
- info = list[i];
- return info;
- }
- }
- }
- return info;
- }
- /// <summary>
- /// 和尾求质合形态的上一次情况
- /// </summary>
- /// <param name="xt">0为合 1为质</param>
- /// <param name="rank"></param>
- /// <returns></returns>
- public static FcssqInfo GetLastHwZhFcssqInfo(ref List<FcssqInfo> list,int xt, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- int size = list.Count;
- List<int> z = new List<int> { 1, 2, 3, 5, 7 };
- List<int> h = new List<int> { 0, 4, 6, 8, 9 };
- for (int i = rank - 2; i >= 0; i--)
- {
- if (xt == 0)
- {
- if (h.Contains(list[i].hw))
- {
- info = list[i];
- return info;
- }
- }
- if (xt == 1)
- {
- if (z.Contains(list[i].hw))
- {
- info = list[i];
- return info;
- }
- }
- }
- return info;
- }
- /// <summary>
- /// 上一次和尾为012路形态的数据
- /// </summary>
- /// <param name="xt">0=0路;1=1路;2=2路</param>
- /// <param name="rank"></param>
- /// <returns></returns>
- public static FcssqInfo GetLastHw012FcssqInfo(ref List<FcssqInfo> list,int xt, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- int size = list.Count;
- for (int i = rank - 2; i >= 0; i--)
- {
- if (xt == 0)
- {
- if (list[i].hw % 3 == 0)
- {
- info = list[i];
- return info;
- }
- }
- if (xt == 1)
- {
- if (list[i].hw % 3 == 1)
- {
- info = list[i];
- return info;
- }
- }
- if (xt == 2)
- {
- if (list[i].hw % 3 == 2)
- {
- info = list[i];
- return info;
- }
- }
- }
- return info;
- }
- /// <summary>
- /// 和尾振幅的上一次数据
- /// </summary>
- /// <param name="zf"></param>
- /// <param name="rank"></param>
- /// <returns></returns>
- public static FcssqInfo GetLastHwZfInfo(ref List<FcssqInfo> list,int zf, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- int size = list.Count;
- for (int i = rank - 2; i >= 0; i--)
- {
- if (i > 0)
- {
- if (Math.Abs(list[i].hw - list[i - 1].hw) == zf)
- {
- info = list[i];
- return info;
- }
- }
- }
- return info;
- }
- #endregion
- #region 跨度相关
- /// <summary>
- /// 双色球上一次跨度val的数据
- /// </summary>
- /// <param name="val"></param>
- /// <param name="rank"></param>
- /// <returns></returns>
- public static FcssqInfo GetLastQkdFcssqInfo(ref List<FcssqInfo> list,int val, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- if (list != null && list.Count > 0)
- {
- for (int i = rank - 2; i >= 0; i--)
- {
- if (list[i].kd == val)
- {
- info = list[i];
- return info;
- }
- }
- }
- return info;
- }
- /// <summary>
- /// 双色球跨度奇偶 上一次
- /// </summary>
- /// <param name="xt"></param>
- /// <param name="rank"></param>
- /// <returns></returns>
- public static FcssqInfo GetLastQkdJoFcssqInfo(ref List<FcssqInfo> list,int xt, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- if (list != null && list.Count > 0)
- {
- for (int i = rank - 2; i >= 0; i--)
- {
- if (xt == 0)
- {
- if (list[i].kd % 2 != 0)
- {
- info = list[i];
- return info;
- }
- }
- if (xt == 1)
- {
- if (list[i].kd % 2 == 0)
- {
- info = list[i];
- return info;
- }
- }
- }
- }
- return info;
- }
- /// <summary>
- /// 双色球跨度大小 前一次情况
- /// </summary>
- /// <param name="xt"></param>
- /// <param name="rank"></param>
- /// <returns></returns>
- public static FcssqInfo GetLastQkdDxFcssqInfo(ref List<FcssqInfo> list,int xt, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- if (list != null && list.Count > 0)
- {
- for (int i = rank - 2; i >= 0; i--)
- {
- if (xt == 0)
- {
- if (list[i].kd > 18)
- {
- info = list[i];
- return info;
- }
- }
- if (xt == 1)
- {
- if (list[i].kd < 19)
- {
- info = list[i];
- return info;
- }
- }
- }
- }
- return info;
- }
- /// <summary>
- /// 双色球跨度质合 前一次情况
- /// </summary>
- /// <param name="xt"></param>
- /// <param name="rank"></param>
- /// <returns></returns>
- public static FcssqInfo GetLastQkdZhFcssqInfo(ref List<FcssqInfo> list,int xt, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- if (list != null && list.Count > 0)
- {
- for (int i = rank - 2; i >= 0; i--)
- {
- if (xt == 0)
- {
- if (ZstUtils.GetZh(list[i].kd) == 0)
- {
- info = list[i];
- return info;
- }
- }
- if (xt == 1)
- {
- if (ZstUtils.GetZh(list[i].kd) == 1)
- {
- info = list[i];
- return info;
- }
- }
- }
- }
- return info;
- }
- #endregion
- /// <summary>
- /// 上一次和值奇偶形态的数据
- /// </summary>
- /// <param name="xt"></param>
- /// <param name="rank"></param>
- /// <returns></returns>
- public static FcssqInfo GetLastHzJoFcssqInfo(ref List<FcssqInfo> list,int xt, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- if (list != null && list.Count > 0)
- {
- for (int i = rank - 2; i >= 0; i--)
- {
- if (xt == 0)
- {
- if (list[i].hz % 2 != 0)
- {
- info = list[i];
- return info;
- }
- }
- if (xt == 1)
- {
- if (list[i].hz % 2 == 0)
- {
- info = list[i];
- return info;
- }
- }
- }
- }
- return info;
- }
- /// <summary>
- /// 上一次和值val的数据
- /// </summary>
- /// <param name="val"></param>
- /// <param name="rank"></param>
- /// <returns></returns>
- public static FcssqInfo GetLastHzFcssqInfo(ref List<FcssqInfo> list,int shz, int ehz, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- if (list != null && list.Count > 0)
- {
- for (int i = rank - 2; i >= 0; i--)
- {
- if (list[i].hz >= shz && list[i].hz <= ehz)
- {
- info = list[i];
- return info;
- }
- }
- }
- return info;
- }
- /// <summary>
- /// 取出个排名的上一次数据
- /// </summary>
- /// <param name="rank"></param>
- /// <returns></returns>
- public static FcssqInfo GetLastFcssqInfo(ref List<FcssqInfo> list,int rank)
- {
- FcssqInfo info = new FcssqInfo();
- 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 FcssqInfo GetNextFcssqInfo(ref List<FcssqInfo> list,int rank)
- {
- FcssqInfo info = new FcssqInfo();
- 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 FcssqInfo GetLastAc012FcssqInfo(ref List<FcssqInfo> list,int val, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- 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 FcssqInfo GetLastAcZhFcssqInfo(ref List<FcssqInfo> list,int xt, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- 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 FcssqInfo GetLastAcDxFcssqInfo(ref List<FcssqInfo> list,int xt, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- 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 FcssqInfo GetLastAcJoFcssqInfo(ref List<FcssqInfo> list,int xt, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- 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 FcssqInfo GetLastAcFcssqInfo(ref List<FcssqInfo> list,int val, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- 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 FcssqInfo GetLastBlueHotFcssqInfo(ref List<FcssqInfo> list,int xt, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- if (list != null && list.Count > 0)
- {
- int size = list.Count;
- for (int i = rank - 2; i >= 0; i--)
- {
- List<int> hot = Fcssq.GetFcssqBlueHotList(ref list,list[i].rank, 16);
- if (xt == 0)
- {
- if (!hot.Contains(list[i].n7))
- {
- info = list[i];
- return info;
- }
- }
- if (xt == 1)
- {
- if (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 FcssqInfo GetLastBlueWsFcssqInfo(ref List<FcssqInfo> list,int val, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- if (list != null && list.Count > 0)
- {
- int size = list.Count;
- for (int i = rank - 2; i >= 0; i--)
- {
- if (ZstUtils.GetHw(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 FcssqInfo GetLastBlueFcssqInfo(ref List<FcssqInfo> list,int val, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- if (list != null && list.Count > 0)
- {
- for (int i = rank - 2; i >= 0; i--)
- {
- if (list[i].n7 == val)
- {
- info = list[i];
- return info;
- }
- }
- }
- return info;
- }
- /// <summary>
- /// 上一期蓝球的区间情况..
- /// </summary>
- /// <param name="qj"></param>
- /// <param name="rank"></param>
- /// <returns></returns>
- public static FcssqInfo GetLastBlueQjFcssqInfo(ref List<FcssqInfo> list,int qj, int rank)
- {
- List<int> b1 = new List<int> { 1, 2, 3, 4 };
- List<int> b2 = new List<int> { 5, 6, 7, 8 };
- List<int> b3 = new List<int> { 9, 10, 11, 12 };
- List<int> b4 = new List<int> { 13, 14, 15, 16 };
- FcssqInfo info = new FcssqInfo();
- if (list != null && list.Count > 0)
- {
- int size = list.Count;
- for (int i = rank - 2; i >= 0; i--)
- {
- if (qj == 1)
- {
- if (b1.Contains(list[i].n7))
- return list[i];
- }
- if (qj == 2)
- {
- if (b2.Contains(list[i].n7))
- return list[i];
- }
- if (qj == 3)
- {
- if (b3.Contains(list[i].n7))
- return list[i];
- }
- if (qj == 4)
- {
- if (b4.Contains(list[i].n7))
- return list[i];
- }
- }
- }
- return info;
- }
- /// <summary>
- /// 上一期的蓝球质合形态...
- /// </summary>
- /// <param name="xt">0=合 1=质</param>
- /// <param name="rank">排名</param>
- /// <returns></returns>
- public static FcssqInfo GetLastBlueZhFcssqInfo(ref List<FcssqInfo> list,int xt, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- int size = list.Count;
- for (int i = rank - 2; i >= 0; i--)
- {
- int n = list[i].n7;
- if (xt == 0)
- {
- if (ZstUtils.GetZh(n) == 0)
- {
- info = list[i];
- return info;
- }
- }
- if (xt == 1)
- {
- if (ZstUtils.GetZh(n) != 0)
- {
- info = list[i];
- return info;
- }
- }
- }
- return info;
- }
- /// <summary>
- /// 上一期的蓝球奇偶形态...
- /// </summary>
- /// <param name="xt">0=偶 1=奇</param>
- /// <param name="rank">排名</param>
- /// <returns></returns>
- public static FcssqInfo GetLastBlueJoFcssqInfo(ref List<FcssqInfo> list,int xt, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- int size = list.Count;
- for (int i = rank - 2; i >= 0; i--)
- {
- int n = list[i].n7;
- if (xt == 0)
- {
- if (n % 2 == 0)
- {
- info = list[i];
- return info;
- }
- }
- if (xt == 1)
- {
- if (n % 2 != 0)
- {
- info = list[i];
- return info;
- }
- }
- }
- return info;
- }
- /// <summary>
- /// 双色球蓝球012路的上一次数据
- /// </summary>
- /// <param name="xt"></param>
- /// <param name="rank"></param>
- /// <returns></returns>
- public static FcssqInfo GetLastBlue012FcssqInfo(ref List<FcssqInfo> list,int xt, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- int size = list.Count;
- for (int i = rank - 2; i >= 0; i--)
- {
- if (ZstUtils.Get012(list[i].n7) == xt)
- {
- info = list[i];
- return info;
- }
- }
- return info;
- }
- /// <summary>
- /// 上一期的蓝球大小形态...
- /// </summary>
- /// <param name="xt">0=小 1=大</param>
- /// <param name="rank">排名</param>
- /// <returns></returns>
- public static FcssqInfo GetLastBlueDxFcssqInfo(ref List<FcssqInfo> list,int xt, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- int size = list.Count;
- for (int i = rank - 2; i >= 0; i--)
- {
- int n = list[i].n7;
- if (xt == 0)
- {
- if (n < 9)
- {
- info = list[i];
- return info;
- }
- }
- if (xt == 1)
- {
- if (n > 8)
- {
- info = list[i];
- return info;
- }
- }
- }
- return info;
- }
- /// <summary>
- /// 红球
- /// 根据当前出号和排名,查询出上一次出此号时的数据
- /// 主要用在遗漏上
- /// </summary>
- /// <param name="val"></param>
- /// <param name="rank"></param>
- /// <returns></returns>
- public static FcssqInfo GetLastRedFcssqInfo(ref List<FcssqInfo> list,int val, int rank)
- {
- FcssqInfo info = new FcssqInfo();
- if (list != null && list.Count > 0)
- {
- 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, list[i].n6 };
- if (kjh.Contains(val))
- {
- info = list[i];
- return info;
- }
- }
- }
- return info;
- }
- #endregion
- #region 最近N期的红球热号...
- /// <summary>
- /// 最近N期的红球热号...
- /// </summary>
- /// <param name="pagesize"></param>
- /// <returns></returns>
- public static List<int> GetFcssqRedHotList(ref List<FcssqInfo> 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);
- rlist.Add(list[i].n6);
- }
- }
- return rlist;
- }
- #endregion
- #region 某期双色球前N期的数据
- /// <summary>
- /// 某期双色球前N期的数据
- /// 用于计算双色球红球冷热号
- /// </summary>
- /// <param name="rank">当前期的排名</param>
- /// <param name="pagesize">前n期</param>
- /// <returns></returns>
- public static List<int> GetFcssqRedHotList(ref List<FcssqInfo> 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);
- rlist.Add(list[i].n6);
- }
- }
- return rlist;
- }
- #endregion
- #region 最近N期的蓝球热号..
- /// <summary>
- /// 最近N期的蓝球热号..
- /// </summary>
- /// <param name="pagesize"></param>
- /// <returns></returns>
- public static List<int> GetFcssqBlueHotList(ref List<FcssqInfo> 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].n7);
- }
- }
- return rlist;
- }
- #endregion
- #region 某期双色球前n期的数据
- /// <summary>
- /// 某期双色球前n期的数据
- /// 用于计算双色球蓝球冷热号
- /// </summary>
- /// <param name="rank">当前期的排名</param>
- /// <param name="pagesize">前n期</param>
- /// <returns></returns>
- public static List<int> GetFcssqBlueHotList(ref List<FcssqInfo> 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].n7);
- }
- }
- return rlist;
- }
- #endregion
- #region 取某一期的数据
- /// <summary>
- /// 取某一期的数据
- /// 根据期数值
- /// </summary>
- /// <param name="qi"></param>
- /// <returns></returns>
- public static FcssqInfo GetFcssqInfo(ref List<FcssqInfo> list,int qi)
- {
- FcssqInfo info = new FcssqInfo();
- int size = list.Count;
- for (int i = 0; i < size; i++)
- {
- if (list[i].qi == qi)
- {
- info = list[i];
- break;
- }
- }
- return info;
- }
- #endregion
- #region 双色球星期x的所有数据列表
- /// <summary>
- /// 双色球星期x的所有数据列表
- /// </summary>
- /// <param name="week"></param>
- /// <returns></returns>
- public static List<FcssqInfo> GetFcssqWeekList(ref List<FcssqInfo> list,int week)
- {
- List<FcssqInfo> rlist = new List<FcssqInfo>();
- 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;
- }
- #endregion
- #region 走势图上的最近xx期数据.
- /// <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>
- /// <param name="day">另外一个星期x</param>
- /// <returns></returns>
- public static List<FcssqInfo> GetFcssqList(ref List<FcssqInfo> datalist, int pagesize, int year, int sqi, int eqi, int week = 0, int day = 0)
- {
- ///星期x的条件时
- ///数据来源不一样.
- List<FcssqInfo> list = new List<FcssqInfo>();
- if (week > 0)
- list = GetFcssqWeekList(ref datalist, week);
- else
- list = datalist;
- List<FcssqInfo> rlist = new List<FcssqInfo>();
- if (list != null && list.Count > 0)
- {
- int size = list.Count;
- if (pagesize > 0)
- {
- rlist.Clear();
- 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 = GetFcssqInfo(ref list,sqi).rank;
- int erank = GetFcssqInfo(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 (day > 0)
- {
- rlist.Clear();
- List<FcssqInfo> temp = new List<FcssqInfo>();
- for (int i = 0; i < size; i++)
- {
- if (list[i].week == day)
- temp.Add(list[i]);
- }
- for (int i = (temp.Count - 120); i < temp.Count; i++)
- {
- rlist.Add(temp[i]);
- }
- return rlist;
- }
- if (pagesize == 0 && year == 0 && eqi == 0 && sqi == 0 && day == 0)
- return list;
- }
- return rlist;
- }
- #endregion
- #region 双色球遗漏表上用到数据
- /// <summary>
- /// 双色球遗漏表上用到数据
- /// </summary>
- /// <param name="eqi"></param>
- /// <returns></returns>
- public static List<FcssqInfo> GetMissFcssqList(ref List<FcssqInfo> list,int eqi)
- {
- List<FcssqInfo> rlist = new List<FcssqInfo>();
- if (eqi > 0)
- {
- int size = list.Count;
- int erank = GetFcssqInfo(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;
- }
- #endregion
- #region 所有双色球数据
- /// <summary>
- /// 所有双色球数据
- /// </summary>
- /// <returns></returns>
- public static List<FcssqInfo> GetFcssqList()
- {
- string key = string.Format(CacheKeys.FCSSQ_DATALIST);
- List<FcssqInfo> list = cache.GetObject<List<FcssqInfo>>(key);
- if (list == null)
- {
- list = FcssqData.GetFcssqList();
- cache.AddObject(key, list, (int)CacheTime.Data);
- }
- return list;
- }
- #endregion
- #region 根据短期数,查询双色球历史同期号
- /// <summary>
- /// 根据短期数,查询双色球历史同期号
- /// </summary>
- /// <param name="shortqi">短期数</param>
- /// <returns></returns>
- public static List<FcssqInfo> GetHistoryFcssqList(ref List<FcssqInfo> list,string shortqi)
- {
- List<FcssqInfo> rlist = new List<FcssqInfo>();
- 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;
- }
- #endregion
- #region 开奖公告相关方法
- /// <summary>
- /// 双色球最近30期开奖数据,完整开奖信息,有缓存
- /// </summary>
- /// <returns></returns>
- public static List<FcssqlongInfo> GetFcssqListTop30(int pagesize=30)
- {
- string key = string.Format(CacheKeys.FCSSQ_KJH_DATA+"-{0}",pagesize);
- List<FcssqlongInfo> list = cache.GetObject<List<FcssqlongInfo>>(key);
- if (list == null)
- {
- list = FcssqData.GetFcssqTop30(pagesize);
- cache.AddObject(key, list, (int)CacheTime.Kjh);
- }
- return list;
- }
- /// <summary>
- /// 包括开机号的双色球列表
- /// </summary>
- /// <param name="pagesize"></param>
- /// <returns></returns>
- public static List<FcssqlongInfo> GetFcssqKjihList(int pagesize = 30)
- {
- string key = string.Format(CacheKeys.FCSSQ_KJH_DATA + "-{0}-kjih", pagesize);
- List<FcssqlongInfo> list = cache.GetObject<List<FcssqlongInfo>>(key);
- if (list == null)
- {
- list = FcssqData.GetFcssqKjihList(pagesize);
- cache.AddObject(key, list, (int)CacheTime.Kjh);
- }
- return list;
- }
- /// <summary>
- /// 获取最新一期开奖信息,完整开奖信息,有缓存
- /// </summary>
- /// <returns></returns>
- public static FcssqlongInfo GetFcssqInfoTop1(ref List<FcssqlongInfo> list)
- {
- FcssqlongInfo info = new FcssqlongInfo();
- if (list.Count > 0)
- {
- info = list[0];
- }
- return info;
- }
- /// <summary>
- /// 根据期数返回某期完整开奖信息,无缓存
- /// </summary>
- /// <param name="qi"></param>
- /// <returns></returns>
- public static FcssqlongInfo GetFcssqInfoByqi(int qi)
- {
- return FcssqData.GetFcssqInfoByQi(qi);
- }
- /// <summary>
- /// 返回某年对应的期数列表,有缓存
- /// </summary>
- /// <param name="year"></param>
- /// <returns></returns>
- public static List<int> GetFcssqQiListByYear(int year)
- {
- string key = string.Format(CacheKeys.FCSSQ_KJH_DATA + "/qilistbyyear/{0}", year);
- List<int> list = cache.GetObject<List<int>>(key);
- if (list == null)
- {
- list = FcssqData.GetFcssqQiListByYear(year);
- cache.AddObject(key, list, (int)CacheTime.System);
- }
- return list;
- }
- #endregion
- }
- }
|