模拟(算法基础)

简介

模拟就是用计算机来模拟题目中要求的操作。

模拟题目通常具有码量大、操作多、思路繁复的特点。由于它码量大,经常会出现难以查错的情况,如果在考试中写错是相当浪费时间的。

技巧

写模拟题时,遵循以下的建议有可能会提升做题速度

  • 在动手写代码之前在草纸上尽可能地写好要实现的流程。
  • 在代码中,尽量把每个部分模块化写成函数、结构体或类。
  • 对于一些可能重复用到的概念,可以统一转化,方便处理:如,某题给你 "YY-MM-DD 时:分" 把它抽取到一个函数,处理成秒,会减少概念混淆。
  • 调试时分块调试。模块化的好处就是可以方便的单独调某一部分。
  • 写代码的时候一定要思路清晰,不要想到什么写什么,要按照落在纸上的步骤写

实际上,上述步骤在解决其它类型的题目时也是很有帮助的。

例题详解

一只长度不计的蠕虫位于  英寸深的井的底部。它每次向上爬  英寸,但是必须休息一次才能再次向上爬。在休息的时候,它滑落了  英寸。之后它将重复向上爬和休息的过程。蠕虫爬出井口需要至少爬多少次?如果蠕虫爬完后刚好到达井的顶部,我们也设作蠕虫已经爬出井口。

package hello;

public class Hello {
	public static void main(String[] args) {
		int n = 100;//井高
		int u = 8;//一次距离
		int d = 2;//下滑距离
		int l =0;//用来累积距离
		int time = 0 ;//次数
		while(true) {//死循环
			 l += u;
			 time++;//考虑到最后一次到顶,就不会下滑
			if( l >=n) {
				break;//当超过n就退出
			}else {
				l -= d;
			}
		}
		System.out.println(time);
	}
}

总结

        让解题更快更清晰,一定要落到草稿上,按照步骤来,光靠想一点写一点肯定是不行的,分步分块逻辑会清晰。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

新地球R

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值