给你一个下标从 0 开始的二维整数数组 brackets ,其中 brackets[i] = [upperi, percenti] ,表示第 i 个税级的上限是 upperi ,征收的税率为 percenti 。税级按上限 从低到高排序(在满足 0 < i < brackets.length 的前提下,upperi-1 < upperi)。
税款计算方式如下:
- 不超过
upper0的收入按税率percent0缴纳 - 接着
upper1 - upper0的部分按税率percent1缴纳 - 然后
upper2 - upper1的部分按税率percent2缴纳 - 以此类推
给你一个整数 income 表示你的总收入。返回你需要缴纳的税款总额。与标准答案误差不超 10-5 的结果将被视作正确答案。
示例 1:
输入:brackets = [[3,50],[7,10],[12,25]], income = 10 输出:2.65000 解释: 前 $3 的税率为 50% 。需要支付税款 $3 * 50% = $1.50 。 接下来 $7 - $3 = $4 的税率为 10% 。需要支付税款 $4 * 10% = $0.40 。 最后 $10 - $7 = $3 的税率为 25% 。需要支付税款 $3 * 25% = $0.75 。 需要支付的税款总计 $1.50 + $0.40 + $0.75 = $2.65 。
示例 2:
输入:brackets = [[1,0],[4,25],[5,50]], income = 2 输出:0.25000 解释: 前 $1 的税率为 0% 。需要支付税款 $1 * 0% = $0 。 剩下 $1 的税率为 25% 。需要支付税款 $1 * 25% = $0.25 。 需要支付的税款总计 $0 + $0.25 = $0.25 。
示例 3:
输入:brackets = [[2,50]], income = 0 输出:0.00000 解释: 没有收入,无需纳税,需要支付的税款总计 $0 。
提示:
1 <= brackets.length <= 1001 <= upperi <= 10000 <= percenti <= 1000 <= income <= 1000upperi按递增顺序排列upperi中的所有值 互不相同- 最后一个税级的上限大于等于
income
这一题很简单,直接跟着题意来就是了。
class Solution {
public:
double calculateTax(vector<vector<int>>& brackets, int income) {
double res = 0;//税款
int pre = 0;//上一税级
for(auto& bracket:brackets){
if(income<bracket[0]){
res+=(double)((income-pre)*bracket[1])/100;
break;
}
else{
res+=(double)((bracket[0]-pre)*bracket[1])/100;
}
pre = bracket[0];
}
return res;
}
};
计算所得税,
给定一个表示税级上限和税率的二维数组,以及个人总收入,计算并返回所需缴纳的税款总额。算法遍历税级数组,根据每个税级的税率计算对应部分的税款,累计得到总税款。
711

被折叠的 条评论
为什么被折叠?



