C++之floor函数

本文详细介绍了使用C++实现银行账户管理的程序,包括账户创建、存款、取款、利息结算等功能,并解释了如何将年利率转换为日利率以准确计算利息。通过实例代码演示,展示了如何利用C++的类、成员函数和数据成员来构建银行账户管理系统。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天在清华大学出版社出版的《c++程序设计基础教程》中,看到一个简单的小程序。它是一个关于银行账户管理的小程序。先不急看代码,首先需要弄清银行是如何结算利息的。如果给定的条件是按照年利率的方式存取款,则首先需要将年利率转成日利率,这样计算出的结果才能与实际大致符合,那么,将利率rate/365也就不奇怪了。程序中还设置了accumulation这个变量专门存储在特定的时间间隔内,涨了多少利息,其中accumulate为常成员函数,这保证了在常成员函数中绝对不会更改数据成员的值。代码如下:

#include "stdafx.h"
#include <iostream>
#include <cmath>
using namespace std;
class SavingsAccount { //存储账户类
private:
	int id;            //账号	
	double balance;    //金额
	double rate;       //存款年利率
	int lastDate;      //上次变更余额的时期
	double accumulation;//余额按日累加之和
	//记录一笔账,date为日期,amount为金额,desc为说明
	void record(int date, double amount);
	double accumulate(int date) const {
		return accumulation + balance * (date - lastDate);

	}
public :
	SavingsAccount(int date, int id, double rate);
	int getId() { return id; }
	double getBalance() { return balance; }
	double getRate() { return rate; }
	void deposit(int date, double amount);
	void withdraw(int date, double amount);
	void settle(int date);
	void show();
};
SavingsAccount::SavingsAccount(int date, int id, double rate) :id(id), balance(0), rate(rate), lastDate(date), accumulation(0) {
	cout << date << "\t#" << id << "is created" << endl;
}
void SavingsAccount::record(int date, double amount) {
	accumulation = accumulate(date);
	lastDate = date;
	amount = floor(amount * 100 + 0.5) / 100;//保留小数点后两位
	balance += amount;
	cout << date << "\t#" << id <<"\t"<< amount<<"\t"<<balance<< endl;
	}
void SavingsAccount::deposit(int date, double amount)
{
	record(date , amount);
}
void SavingsAccount::withdraw(int date, double amount)
{
	if (amount > getBalance())
	{
		cout << "Error:not enough money" << endl;
	
	}
	else {
		record(date, -amount);
	}
}
void SavingsAccount::settle(int date) {
	double interest = accumulate(date)*rate / 365;
	if (interest != 0)
		record(date, interest);
	accumulation = 0;

}
void SavingsAccount::show() {
	cout << "#" << id << "\tBalance: " << balance;
}
int main()
{
	SavingsAccount sa0(1, 21325302, 0.015);
	SavingsAccount sa1(1, 58320212, 0.015);

	sa0.deposit(5, 5000);
	sa1.deposit(25, 10000);
	sa0.deposit(45, 5500);
	sa1.withdraw(60, 4000);
	sa0.settle(90);
	sa1.settle(90);
	sa0.show(); cout << endl;
	sa1.show(); cout << endl;
	return 0;
}

没有用到什么新的C++语法特性。首先给出了SavingsAccount类的定义。其中floor函数,是向下取整函数,声明在头文件cmath中。floor(x+0.5)常常用来进行四舍五入取整。拓展一下,ceil为向上取整函数。

运行结果:

204916_r1QE_2392809.png

转载于:https://my.oschina.net/donngchao/blog/520033

### C++ 中 `floor` 函数的用法 在 C++ 编程中,`floor` 函数属于 `<cmath>` 数学库的一部分,主要用于返回小于或等于给定数值的最大整数[^1]。这意味着对于任意浮点数输入,`floor` 将始终向下舍入到最接近的整数值。 #### 使用方法 要使用 `floor` 函数,需先包含头文件 `<cmath>` 或 `<math.h>`。以下是基本语法: ```cpp double floor(double x); float floor(float x); long double floor(long double x); ``` 参数 `x` 是需要进行向下取整操作的浮点数,而返回值则是不大于该浮点数的最大整数值,类型与传入参数一致[^4]。 #### 示例代码 下面展示了一个简单的例子来演示 `floor` 函数的行为: ```cpp #include <iostream> #include <cmath> // 包含 math 库以支持 floor 函数 using namespace std; int main() { double num1 = 2.3; double num2 = -2.8; cout << "Floor of " << num1 << " is " << floor(num1) << endl; // 输出 Floor of 2.3 is 2 cout << "Floor of " << num2 << " is " << floor(num2) << endl; // 输出 Floor of -2.8 is -3 return 0; } ``` 上述程序展示了正负两种情况下的 `floor` 结果。需要注意的是,当输入为负数时,`floor` 同样遵循向更小方向取整的原则,因此 `-2.8` 被映射至 `-3`[^5]。 #### 特殊注意事项 尽管可以直接调用标准库中的 `floor` 实现所需功能,但在特定情况下可能还需要考虑数据类型的转换问题。例如,在将结果强制转化为 `int` 类型之前应确保不会因溢出而导致错误行为[^3]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值