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



有没有一瞬间让你觉得他/她其实很可怜? 第3页

        

user avatar   guo-guo-miao-94 网友的相关建议: 
      

把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-20 - tinynew.org. All Rights Reserved.
© 2025-04-20 - tinynew.org. 保留所有权利