Java实现月工资个人所得税及各保险计算问题

简介: Java实现月工资个人所得税及各保险计算问题

使用系统:Windows10;


使用JDK:Java SE Development Kit 17.0.2;


使用开发环境:eclipse。

一、代码

package javajichu;
import java.util.Scanner;
public class SuiFei {
  public static void main(String[] args) {
  System.out.println("按工资标准缴纳相应的税费:");
  Scanner in = new Scanner(System.in);
  float money =0, old = 0, medicare = 0, outWork = 0, house = 0, total = 0;
  System.out.print("请输入应发工资:");
  money = in.nextFloat();
  old = (float) (money * 0.08);// 计算养老保险,税率为8%
  medicare = (float) (money * 0.02);// 计算医保保险,税率为2%
  outWork = (float) (money * 0.002);// 计算失业保险,税率为0.2%
  house = money * 0.12f;// 计算住房公积金,税率为12%
  total = old + medicare + outWork + house;
  money = money - total;
  float gerenTax = geren(money);
  float income = money - gerenTax;
  System.out.println("养老保险:" + old + "元");
  System.out.println("医疗保险:" + medicare + "元");
  System.out.println("失业保险:" + outWork + "元");
  System.out.println("住房公积金:" + house + "元");
  System.out.println("应缴纳保险总额:" + total + "元");
  System.out.println("应交个人所得税:" + gerenTax + "元");
  System.out.println("税后实际收入为:" + income + "元");
  }
  //计算个人所得税,按照2022年最新个人所得税税率表计算
  public static float geren(float money) {
  float one = 0, two = 0, three = 0, four = 0, five = 0, six = 0;
  one = (8000 - 5000) * 0.03f;//第一档满额缴费
  two = (17000 - 8000) * 0.1f;//第二档满额缴费
  three = (30000 - 17000) * 0.2f;//第三档满额缴费
  four = (40000 - 30000) * 0.25f;//第四档满额缴费
  five = (60000 - 40000) * 0.3f;//第五档满额缴费
  six = (85000 - 60000) * 0.35f;//第六档满额缴费
  float tax = 0;
  if (money <= 5000)
    tax = 0;//级别1税率
  else if (money <= 8000)
    tax = (money - 5000) * 0.03f;//级别2税率
  else if (money <= 17000)
    tax = (money - 8000) * 0.1f + one;//级别3税率
  else if (money <= 30000)
    tax = (money - 17000) * 0.2f + two + one;//级别4税率
  else if (money <= 40000)
    tax = (money - 30000) * 0.25f + three + two + one;//级别5税率
  else if (money <= 60000)
    tax = (money - 40000) * 0.3f + four + three + two + one;//级别6税率
  else if (money <= 85000)
    tax = (money - 60000) * 0.35f + five + four + three + two + one;//级别7税率
  else
    tax = (money - 85000) * 0.45f + six + five + four + three + two + one;//级别8税率
  return tax;
  }
}

二、运行结果

2bb50667835446cd8dd657030589455d.png

三、粗浅理解

       在解决此类问题时,需要先在网上找最新的税率计算利率,找到之后把养老保险,医疗保险,事业保险和住房公积金根据总工资计算的保险金额计算出来。


       个人所得税是减去各个保险的金额再计算的,所以减去之后,这里我把个人所得税用到自定方法中去计算,把减去各个保险的工资金额传入自定义方法中计算。


       根据最新个人所得税利率计算规律,利用if...else多分支语句,把个所得税f多种情况进行计算,根据传入的数,去对应的分支进行计算,然后返回这个数。


       最后把得到的各个值在相应的输出语句中输出。

目录
相关文章
|
1月前
|
存储 分布式计算 Java
存算分离与计算向数据移动:深度解析与Java实现
【11月更文挑战第10天】随着大数据时代的到来,数据量的激增给传统的数据处理架构带来了巨大的挑战。传统的“存算一体”架构,即计算资源与存储资源紧密耦合,在处理海量数据时逐渐显露出其局限性。为了应对这些挑战,存算分离(Disaggregated Storage and Compute Architecture)和计算向数据移动(Compute Moves to Data)两种架构应运而生,成为大数据处理领域的热门技术。
67 2
|
1月前
|
分布式计算 Java MaxCompute
ODPS MR节点跑graph连通分量计算代码报错java heap space如何解决
任务启动命令:jar -resources odps-graph-connect-family-2.0-SNAPSHOT.jar -classpath ./odps-graph-connect-family-2.0-SNAPSHOT.jar ConnectFamily 若是设置参数该如何设置
|
2月前
|
机器学习/深度学习 算法 搜索推荐
让星星⭐月亮告诉你,Java冒泡排序及其时间复杂度计算
冒泡排序是一种简单的排序算法,通过多次遍历数组,每次比较相邻元素并交换位置,将较小的元素逐步移至数组前端。第一轮结束后,最小值会位于首位;第二轮则将次小值置于第二位,依此类推。经过 (n-1) 轮遍历后,数组完成排序。冒泡排序的时间复杂度为 O(n²),在最优情况下(已排序数组)时间复杂度为 O(n)。示例代码展示了如何实现冒泡排序。
69 1
|
2月前
|
分布式计算 资源调度 Hadoop
Hadoop-10-HDFS集群 Java实现MapReduce WordCount计算 Hadoop序列化 编写Mapper和Reducer和Driver 附带POM 详细代码 图文等内容
Hadoop-10-HDFS集群 Java实现MapReduce WordCount计算 Hadoop序列化 编写Mapper和Reducer和Driver 附带POM 详细代码 图文等内容
119 3
|
1月前
|
Java API Apache
java集合的组内平均值怎么计算
通过本文的介绍,我们了解了在Java中计算集合的组内平均值的几种方法。每种方法都有其优缺点,具体选择哪种方法应根据实际需求和场景决定。无论是使用传统的循环方法,还是利用Java 8的Stream API,亦或是使用第三方库(如Apache Commons Collections和Guava),都可以有效地计算集合的组内平均值。希望本文对您理解和实现Java中的集合平均值计算有所帮助。
40 0
|
2月前
|
消息中间件 Java Kafka
Flink-04 Flink Java 3分钟上手 FlinkKafkaConsumer消费Kafka数据 进行计算SingleOutputStreamOperatorDataStreamSource
Flink-04 Flink Java 3分钟上手 FlinkKafkaConsumer消费Kafka数据 进行计算SingleOutputStreamOperatorDataStreamSource
62 1
|
4月前
|
Rust JavaScript Java
简单对比Java、Python、Go、Rust等常见语言计算斐波拉契数的性能
简单对比Java、Python、Go、Rust等常见语言计算斐波拉契数的性能
|
5月前
|
搜索推荐 Java 大数据
Java中的数据流处理与流式计算实现
Java中的数据流处理与流式计算实现
|
5月前
|
设计模式 并行计算 安全
Java面试题:如何使用设计模式优化多线程环境下的资源管理?Java内存模型与并发工具类的协同工作,描述ForkJoinPool的工作机制,并解释其在并行计算中的优势。如何根据任务特性调整线程池参数
Java面试题:如何使用设计模式优化多线程环境下的资源管理?Java内存模型与并发工具类的协同工作,描述ForkJoinPool的工作机制,并解释其在并行计算中的优势。如何根据任务特性调整线程池参数
58 0
|
5月前
|
并行计算 监控 Java
Java中的并行计算与任务分发策略
Java中的并行计算与任务分发策略