百科问答小站 logo
百科问答小站 font logo



你知道哪些猛烈的「翻车」事故? 第3页

        

user avatar   yan-si-de-yu-92-64 网友的相关建议: 
      

把buff机制做成一个图(graph)。

每个buff是一个节点,每个状态也是一个节点。

现在无敌状态受两种状态影响(A、C),那么A、C各有一条边指向无敌状态。

无敌状态判定时,遍历所有输入节点(也就是A、C),有一个buff生效就生效。A、C如果也有自己的状态依赖,那就进行深度遍历依次判定。

如果存在“覆盖”,比如例子中b buff覆盖a buff,那么B有一条边指向A,判定时B的优先级比A高。A取消了,B还在生效。

整个graph必须是个有向无圈图(DAG),有圈说明循环依赖,判定时会宕机(halting)。

DAG可以进行拓扑排序,排完序后就是个一维数组,每帧可以按照这个优先级进行判定,省去了深度遍历的消耗,实现更简单。

不建议手动给状态排优先级,维护起来费劲。




        

相关话题

  怎么学习申论(学了申论,成绩反而低了)? 
  拉屎有哪些文雅一点的叫法? 
  有哪些症状(看似)很凶险却大多能自愈的疾病? 
  有哪些把观众智商按在地上摩擦的操作? 
  人会被高压电「吸」过去吗? 
  《甄嬛传》里有哪些有趣的弹幕? 
  有没有可能存在不遵循支配等级制度的社会? 
  男生需要的基本款的手表有哪些? 
  女生之间的勾心斗角在实际生活中会凶残到什么程度? 
  房地产泡沫破碎会给人们的生活造成哪些影响? 

前一个讨论
有没有什么事情的真相是大众永远无法接受的?
下一个讨论
有哪些女人杀害男人的刑事案件?





© 2025-04-18 - tinynew.org. All Rights Reserved.
© 2025-04-18 - tinynew.org. 保留所有权利