docs/basic/simulate.md
本页面将简要介绍模拟算法.
模拟就是用计算机来模拟题目中要求的操作.
模拟题目通常具有码量大、操作多、思路繁复的特点.由于它码量大,经常会出现难以查错的情况,如果在考试中写错是相当浪费时间的.
写模拟题时,遵循以下的建议有可能会提升做题速度:
实际上,上述步骤在解决其它类型的题目时也是很有帮助的.
???+ note "Climbing Worm" 一只长度不计的蠕虫位于 $n$ 英寸深的井的底部.它每次向上爬 $u$ 英寸,但是必须休息一次才能再次向上爬.在休息的时候,它滑落了 $d$ 英寸.之后它将重复向上爬和休息的过程.蠕虫爬出井口需要至少爬多少次?如果蠕虫爬完后刚好到达井的顶部,我们也设作蠕虫已经爬出井口.
??? note "解题思路" 直接使用程序模拟蠕虫爬井的过程就可以了.用一个循环重复蠕虫的爬井过程,当攀爬的长度超过或者等于井的深度时跳出.
??? note "参考代码"
=== "C++"
cpp --8<-- "docs/basic/code/simulate/simulate_1.cpp"
=== "Python"
```python
--8<-- "docs/basic/code/simulate/simulate_1.py"
```
=== "Java"
```java
--8<-- "docs/basic/code/simulate/simulate_1.java"
```