模拟算法.算法要点

本文介绍了使用模拟法解决数学问题的方法,通过建立条件关系,创建数学模型,详细阐述了解决零花钱问题的步骤,包括输入输出分析和程序编写调试。

模拟法概要

所谓模拟法,就是用计算机模拟某个过程,通过改变数学模型的各种参数,进而观察变更这些参数所引起的过程状态的变化,然后从中得出解答。

模拟题的算法一般都不太复杂,关键是所有条件都不能遗漏并要把条件分析清楚。

解答模拟题通常的步骤是:

(1)认真仔细的读懂题目。模拟题的描述通常都比较详细,篇幅一般都比较长,应该边阅读边将有关的条件一条条地记录下来,阅读完成后要反复核对,绝对不能有错漏。

(2)建立各个条件之间的关系,最好用一些简明的表格列出。

(3)认真分析这些关系,并建立这些关系的数学模型。

(4)规划各个模块的结构,用相应的语言、逐步求精的方法描述具体的算法。

(5)编写程序,调试并运行。

(6)检查题目给出的样例能否通过。

竞赛题目中一般都会给出输入输出样例,以便检查程序的输入输出格式是否正确,但这些样例往往会比竞赛时评判所用的测试数据简单,所以你不能满足于通过这些样例,还要尽量自拟一些更复杂、更全面的测试数据来检查程序的正确性。经过反复的调试、检查,才算完成该题。

例题

零花钱

题目描述

小明每天都可以从妈妈那里领到零花钱,第 1 天可以领到 1 块钱,第2天可以领到 2 块钱......,第 i 天可以领到 i 块钱,如果小明领到零花钱后,手上的零花钱是 3 的倍数时,小明就会将他手上所有零花钱的三分之一存在妈妈那里(假设小明的零花钱从来不花!)。第 K 天的时候小明手上有多少零花钱呢?

输入格式

一个整数 K ,K <= 100

输出格式

一个整数,小明手上的零花钱。

样例

輸入資料 1

2

輸出資料 1

2

参考代码

#include<bits/stdc++.h>
using namespace std;
int k,s;
int main()
{

	cin>>k;

	for(int i=1;i<=k;i++)
	{
		s=s+i;  //第 i 天的零花钱为i元

		if(s%3==0) s=s/3*2;  //如果手上的零花钱s为3的倍数,存三分之一在妈妈那,自己留三分之二。
	}
	cout<<s;

	return 0;

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值