getDecks(); 设置

 private void getDecks()
{
Dictionary<string, int> tmpDeck = new Dictionary<string, int>(startDeck);
List<GraveYardItem> graveYard = new List<GraveYardItem>();
Dictionary<CardDB.cardIDEnum, int> og = new Dictionary<CardDB.cardIDEnum, int>();
Dictionary<CardDB.cardIDEnum, int> eg = new Dictionary<CardDB.cardIDEnum, int>();
int owncontroler = TritonHs.OurHero.GetTag(GAME_TAG.CONTROLLER);
int enemycontroler = TritonHs.EnemyHero.GetTag(GAME_TAG.CONTROLLER);
turnDeck.Clear();
noDuplicates = false; List<HSCard> allcards = TritonHs.GetAllCards(); int allcardscount = allcards.Count;
for (int i = ; i < allcardscount; i++)
{
HSCard entity = allcards[i];
if (entity.Id == null || entity.Id == "") continue; if (CardDB.Instance.cardIdstringToEnum(entity.Id) == CardDB.cardIDEnum.UNG_116t) ownMinionsCost0 = true; if (entity.GetZone() == Triton.Game.Mapping.TAG_ZONE.GRAVEYARD)
{
CardDB.cardIDEnum cide = CardDB.Instance.cardIdstringToEnum(entity.Id);
GraveYardItem gyi = new GraveYardItem(cide, entity.EntityId, entity.GetTag(GAME_TAG.CONTROLLER) == owncontroler);
graveYard.Add(gyi); if (entity.GetTag(GAME_TAG.CONTROLLER) == owncontroler)
{
if (og.ContainsKey(cide)) og[cide]++;
else og.Add(cide, );
}
else if (entity.GetTag(GAME_TAG.CONTROLLER) == enemycontroler)
{
if (eg.ContainsKey(cide)) eg[cide]++;
else eg.Add(cide, );
}
if (cide == CardDB.cardIDEnum.UNG_067t1) ownCrystalCore = ;
} string entityId = entity.Id;
Triton.Game.Mapping.TAG_ZONE entZone = entity.GetZone();
if (i < )
{
if (entityId != "")
{
if (entZone == Triton.Game.Mapping.TAG_ZONE.DECK) continue;
if (tmpDeck.ContainsKey(entityId)) tmpDeck[entityId]--;
}
}
else if (i >= && entity.ControllerId == owncontroler)
{
if (extraDeck.ContainsKey(i))
{
if (entityId != "" && entityId != extraDeck[i].id) extraDeck[i].setId(entityId);
if ((entZone == Triton.Game.Mapping.TAG_ZONE.DECK) != extraDeck[i].isindeck) extraDeck[i].setisindeck(entZone == Triton.Game.Mapping.TAG_ZONE.DECK);
}
else if (entZone == Triton.Game.Mapping.TAG_ZONE.DECK)
{
extraDeck.Add(i, new extraCard(entityId, true));
}
}
} Action a = Ai.Instance.bestmove;
foreach (var c in extraDeck)
{
if (c.Value.isindeck == false) continue;
CardDB.cardIDEnum ce;
string entityId = c.Value.id;
if (entityId == "")
{
if (a != null)
{
switch (a.actionType)
{
case actionEnum.playcard:
switch (a.card.card.cardIDenum)
{
case CardDB.cardIDEnum.LOE_104: goto case CardDB.cardIDEnum.BRM_007;
case CardDB.cardIDEnum.BRM_007:
if (a.target != null) entityId = a.target.handcard.card.cardIDenum.ToString();
break;
case CardDB.cardIDEnum.LOE_002: entityId = "LOE_002t"; break;
case CardDB.cardIDEnum.LOE_079: entityId = "LOE_019t"; break;
case CardDB.cardIDEnum.LOE_019t: entityId = "LOE_019t2"; break;
case CardDB.cardIDEnum.LOE_110: entityId = "LOE_110t"; break;
}
break;
}
}
if (entityId == "")
{
var oldCardsOut = Probabilitymaker.Instance.enemyCardsOut;
foreach (var tmp in eg)
{
if (oldCardsOut.ContainsKey(tmp.Key) && tmp.Value == oldCardsOut[tmp.Key]) continue;
switch (tmp.Key)
{
case CardDB.cardIDEnum.AT_035: entityId = "AT_035t"; break;
case CardDB.cardIDEnum.GVG_031: entityId = "aiextra1"; break;
case CardDB.cardIDEnum.LOE_111: entityId = "LOE_111"; break;
}
}
if (entityId == "" && lastpf != null)
{
int num = ;
foreach (Minion m in this.enemyMinions)
{
if (m.handcard.card.cardIDenum == CardDB.cardIDEnum.GVG_056) num++;
}
if (num > )
{
foreach (Minion m in lastpf.enemyMinions)
{
if (m.handcard.card.cardIDenum == CardDB.cardIDEnum.GVG_056) num--;
}
}
if (num > ) entityId = "GVG_056t";
else
{
num = ;
foreach (Minion m in lastpf.ownMinions)
{
if (m.handcard.card.cardIDenum == CardDB.cardIDEnum.GVG_035) num++;
}
if (num > )
{
foreach (Minion m in this.ownMinions)
{
if (m.handcard.card.cardIDenum == CardDB.cardIDEnum.GVG_035) num--;
}
}
if (num > ) entityId = "GVG_035";
}
}
}
if (entityId == "") entityId = "aiextra1";
}
c.Value.setId(entityId);
ce = CardDB.Instance.cardIdstringToEnum(entityId);
if (turnDeck.ContainsKey(ce)) turnDeck[ce]++;
else turnDeck.Add(ce, );
}
foreach (var c in tmpDeck)
{
if (c.Value < ) continue;
CardDB.cardIDEnum ce = CardDB.Instance.cardIdstringToEnum(c.Key);
if (ce == CardDB.cardIDEnum.None) continue;
if (turnDeck.ContainsKey(ce)) turnDeck[ce] += c.Value;
else turnDeck.Add(ce, c.Value);
} Probabilitymaker.Instance.setOwnCardsOut(og);
Probabilitymaker.Instance.setEnemyCardsOut(eg);
bool isTurnStart = false;
if (Ai.Instance.nextMoveGuess.mana == -)
{
isTurnStart = true;
Ai.Instance.updateTwoTurnSim();
}
Probabilitymaker.Instance.setGraveYard(graveYard, isTurnStart); if (startDeck.Count == ) return;
noDuplicates = true;
foreach (int i in turnDeck.Values)
{
if (i > )
{
noDuplicates = false;
break;
}
}
}

最终的实现

https://github.com/ChuckHearthstone/SilverFish/blob/master/DefaultRoutine/Chuck.SilverFish/Helpers/EvenDeckHelper.cs

HearthBuddy炉石兄弟 格雷迈恩的更多相关文章

  1. HearthBuddy炉石兄弟 Method 'Entity.GetRace' not found.

    解决方案 namespace Triton.Game.Mapping{// Token: 0x020004A4 RID: 1188[Attribute38("Entity")]pu ...

  2. HearthBuddy炉石兄弟 如何调试ai

    Sepefeets's update to botmaker's Silverfish AI This AI is a Custom Class for Hearthranger and Hearth ...

  3. HearthBuddy炉石兄弟 Method 'CollectionDeckBoxVisual.IsValid' not found.

    [CollectionManagerScene_COLLECTION] An exception occurred when calling CacheCustomDecks: System.Miss ...

  4. 炉石兄弟 修复图腾师问题 by大神beebee102, 还有阴燃电鳗

    修复图腾师问题   beebee102 修复了先摇图腾再下图腾师的问题,另外加了阴燃电鳗的sim卡.在兄弟策略的模拟程序中测试了没问题,真机没有试过,麻烦吧友测试了回复一下.链接: [有效] http ...

  5. [.NET] ConfuserEx脱壳工具打包

    [.NET] ConfuserEx脱壳工具打包 ConfuserEx 1.0.0脱壳步骤        Written by 今夕何夕[W.B.L.E. TeAm] 1.先用UnconfuserEx把 ...

  6. Playfield 类方法的注释

    前言 本篇随笔的底包采用的是百度炉石兄弟吧20200109折腾版中自带的 routines 文件. 本次仅为绝大多数方法添加 xml 注释和简单解析,没有具体解析与重构. Playfield 类方法众 ...

  7. HearthBuddy卡组

    偶数萨 手打两天已上传说,各位加油  欧洲牧羊人 ### 火元素换艾雅# 职业:萨满祭司# 模式:狂野模式## 2x (2) 图腾魔像        # 2x (2) 大漩涡传送门   # 2x (2 ...

  8. HearthBuddy 第一次调试

    HearthBuddy https://www.jiligame.com/70639.html 解压缩包,打开hearthbuddy.exe直接运行就可以:不用替换mono.dll直接可用:不需要校验 ...

  9. angularjs $emit $on $broadcast 父子 兄弟之间传值

    父子之间 <div ng-controller="ParentCtrl"> <div ng-controller="ChildCtrl"> ...

随机推荐

  1. Activiti使用总结

    工作流在我们日常的工作中用得可谓相当普及,尤其在企业内部管理系统,如考勤.财务.合同等系统中更是离不开它.在我们金融科技领域,工作流主要用于贷款审批.风控审核等环节.早期工作流在企业信息化发挥着很重要 ...

  2. “最不合格”的SAP应聘者: 从大学生到SAP成都研究院开发工程师

    让我们把时光之轮倒拨回2006年,SAP成都研究院刚刚成立的时候,有一位年轻的电子科技大学研究生,网名雷米兰(这名字一看就是AC米兰铁杆粉丝),加入了SAP成都研究院并被派遣到SAP德国总部进行实习. ...

  3. 010.简单查询、分组统计查询、多表连接查询(sql实例)

    -------------------------------------day3------------ --添加多行数据:------INSERT [INTO] 表名 [(列的列表)] --SEL ...

  4. 拆机联想ideapad s500

    这是我第一次拆机,中间也是经历了各种艰难险阻,最后还算是成功.首先,说一下拆机得目的:很简单,为了加一个内存条:下面具体说拆机得步骤: 第一步,在网上查攻略,刚开始的时候,并没有很详细的具体到机型,只 ...

  5. Physical Education Lessons CodeForces - 915E (动态开点线段树)

    Physical Education Lessons CodeForces - 915E This year Alex has finished school, and now he is a fir ...

  6. PAT乙级1041

    题目链接 https://pintia.cn/problem-sets/994805260223102976/problems/994805281567916032 题解 简单的信息录入和查询而已. ...

  7. Spring入门篇——第3章 Spring Bean装配(上)

    第3章 Spring Bean装配(上) 介绍Bean的作用域.生命周期.Aware接口.自动装配和Resource等内容. 3-1 Spring Bean装配之Bean的配置项及作用域 从上至下依次 ...

  8. CF15E Triangles

    思路 有四种方法,L,R,L->R,只走上面的小三角形 然后组合方案数\(2f^2+8f+10\) 然后求f,递推一下就好啦(其实是太麻烦了) 时间和空间复杂度都是\(O(n)\) 代码 #in ...

  9. Maven打Dubbo可执行Jar

    POM文件中添加如下配置: <build> <finalName>test-jar</finalName> <resources> <resour ...

  10. js文件中使用el表达式问题

    作者:Sang 单独js文件不能用el表达式. 首先,JSP是由服务端执行的,EL表达式自然也由服务端解析执行,因此如果EL所在的脚本在JSP页面内,它是可以获取到值的,这个值在服务器端返回到浏览器端 ...