1. 程式人生 > >工資計算-CCF往屆題

工資計算-CCF往屆題

1.題目的本意:提供稅後工資,求得稅前工資。 2.思路:根據提供的工資交稅辦法,暫時無法產生由稅後到稅前的數學對映關係。所以,暴力計算構建對映表(由稅前到稅後),然後查表輸出即可。 3.做法:注意到所有評測資料保證小明的稅前工資為一個整百的數,所以就用整百數來構建對映表。
試題編號: 201612-2
試題名稱: 工資計算
時間限制: 1.0s
記憶體限制: 256.0MB
問題描述: 問題描述   小明的公司每個月給小明發工資,而小明拿到的工資為交完個人所得稅之後的工資。假設他一個月的稅前工資(扣除五險一金後、未扣稅前的工資)為S元,則他應交的個人所得稅按如下公式計算:
  1) 個人所得稅起徵點為3500元,若S不超過3500,則不交稅,3500元以上的部分才計算個人所得稅,令A=S-3500元;
  2) A中不超過1500元的部分,稅率3%;
  3) A中超過1500元未超過4500元的部分,稅率10%;
  4) A中超過4500元未超過9000元的部分,稅率20%;
  5) A中超過9000元未超過35000元的部分,稅率25%;
  6) A中超過35000元未超過55000元的部分,稅率30%;
  7) A中超過55000元未超過80000元的部分,稅率35%;
  8) A中超過80000元的部分,稅率45%;
  例如,如果小明的稅前工資為10000元,則A=10000-3500=6500元,其中不超過1500元部分應繳稅1500×3%=45元,超過1500元不超過4500元部分應繳稅(4500-1500)×10%=300元,超過4500元部分應繳稅(6500-4500)×20%=400元。總共繳稅745元,稅後所得為9255元。
  已知小明這個月稅後所得為T元,請問他的稅前工資S是多少元。 輸入格式   輸入的第一行包含一個整數T,表示小明的稅後所得。所有評測資料保證小明的稅前工資為一個整百的數。 輸出格式   輸出一個整數S,表示小明的稅前工資。 樣例輸入 9255 樣例輸出 10000 評測用例規模與約定   對於所有評測用例,1 ≤ T ≤ 100000。

import java.util.Scanner;
import java.util.HashMap;


public class Main{
	public static void main(String[] args){
		
		Scanner in=new Scanner(System.in);
		int hou=in.nextInt();
		HashMap<Integer,Integer> yingshe=new HashMap<Integer,Integer>(20000);
		
		int temp=0;
		int shuihou=0;
		
		for(int i=1;i<20000;i++){
			temp=i*100;
			temp-=3500;
			if(temp<=0){
				yingshe.put(i*100,i*100);
			}else if(temp<=1500){
				shuihou=(int)(temp*(1-0.03)+3500);
				yingshe.put(shuihou,i*100);
			}else if(temp<=4500){
				shuihou=(int)((temp-1500)*(1-0.1)+1500*(1-0.03)+3500);
				yingshe.put(shuihou,i*100);
			}else if(temp<9000){
				shuihou=(int)((temp-4500)*(1-0.2)+(4500-1500)*(1-0.1)+1500*(1-0.03)+3500);
				yingshe.put(shuihou,i*100);
			}else if(temp<35000){
				shuihou=(int)((temp-9000)*(1-0.25)+(9000-4500)*(1-0.2)+(4500-1500)*(1-0.1)+1500*(1-0.03)+3500);
				yingshe.put(shuihou,i*100);
			}else if(temp<55000){
				shuihou=(int)((temp-35000)*(1-0.3)+(35000-9000)*(1-0.25)+(9000-4500)*(1-0.2)+(4500-1500)*(1-0.1)+1500*(1-0.03)+3500);
				yingshe.put(shuihou,i*100);
			}else if(temp<80000){
				shuihou=(int)((temp-55000)*(1-0.35)+(55000-35000)*(1-0.3)+(35000-9000)*(1-0.25)+(9000-4500)*(1-0.2)+(4500-1500)*(1-0.1)+1500*(1-0.03)+3500);
				yingshe.put(shuihou,i*100);
			}else{
				shuihou=(int)((temp-80000)*(1-0.45)+(80000-55000)*(1-0.35)+(55000-35000)*(1-0.3)+(35000-9000)*(1-0.25)+(9000-4500)*(1-0.2)+(4500-1500)*(1-0.1)+1500*(1-0.03)+3500);
				yingshe.put(shuihou,i*100);
			}
		}
		
		System.out.println(yingshe.get(hou));
		
	}
}