销售员工资计算(Sales Commissions)


代码如下:

package example;
//JHTP Exercise 7.10: Sales Commissions
//by pandenghuang@163.com
/**(Sales Commissions) Use a one-dimensional array to solve the following problem: A company
pays its salespeople on a commission basis. The salespeople receive $200 per week plus 9% of
their gross sales for that week. For example, a salesperson who grosses $5,000 in sales in a week receives
$200 plus 9% of $5,000, or a total of $650. Write an application (using an array of counters)
that determines how many of the salespeople earned salaries in each of the following ranges (assume
that each salesperson’s salary is truncated to an integer amount):
a) $200–299
b) $300–399
c) $400–499
d) $500–599
e) $600–699
f) $700–799
g) $800–899
h) $900–999
i) $1,000 and over
Summarize the results in tabular format.*/
import java.util.Scanner;

public class SalesCommission 
{
	public static int calSalary(double grossSales){
		int salary=0;
		
		salary=200+(int)(grossSales*0.09);
		return salary;
	}
	
	public static void main(String[] args)
{
	double grossSales=0.0;
	double totalGrossSales=0.0;
	int salary=0;
	int totalSalary=0;
	int count=0;
	int[] frequency=new int[9];

	Scanner input=new Scanner(System.in);
	
	do {
		System.out.print("请输入下一位销售员当月的销售总额(整数,输入-1退出):");
		grossSales=input.nextDouble();
		if(grossSales==-1)
			System.out.print("录入已结束。\n");
		else
		{
			salary=calSalary(grossSales);
			if (salary>=1000){
				++frequency[0];
				++count;
				totalSalary+=salary;
				totalGrossSales+=grossSales;}
			else if(salary>=900){
				++frequency[1];
				++count;
				totalSalary+=salary;
				totalGrossSales+=grossSales;}
			else if(salary>=800){
				++frequency[2];
				++count;
				totalSalary+=salary;
				totalGrossSales+=grossSales;}
			else if(salary>=700){
				++frequency[3];
				++count;
				totalSalary+=salary;
				totalGrossSales+=grossSales;}
			else if(salary>=600){
				++frequency[4];
				++count;
				totalSalary+=salary;
				totalGrossSales+=grossSales;}
			else if(salary>=500){
				++frequency[5];
				++count;
				totalSalary+=salary;
				totalGrossSales+=grossSales;}
			else if(salary>=400){
				++frequency[6];
				++count;
				totalSalary+=salary;
				totalGrossSales+=grossSales;}
			else if(salary>=300){
				++frequency[7];
				++count;
				totalSalary+=salary;
				totalGrossSales+=grossSales;}
			else if(salary>=200){
				++frequency[8];
				++count;
				totalSalary+=salary;
				totalGrossSales+=grossSales;}
			}
	} 
	while (grossSales!=-1);
	System.out.printf("\n共录入了%d位销售员的业绩:\n总销售额为:%.2f美元,工资总额为:%d美元\n",count,totalGrossSales,totalSalary);
	System.out.printf("工资分布如下表所示:\n");
	for (int i=0;i<9;i++){
		if (i<8)
			System.out.print("$"+100*(i+2)+"-"+(100*(i+3)-1)+"\t"+frequency[9-i-1]+"\n");
		if (i==8)
			System.out.print("$"+100*(i+2)+"以上"+"\t"+frequency[9-i-1]+"\n");
	}
}
}


运行结果:

请输入下一位销售员当月的销售总额(整数,输入-1退出):1000
请输入下一位销售员当月的销售总额(整数,输入-1退出):3000
请输入下一位销售员当月的销售总额(整数,输入-1退出):8000
请输入下一位销售员当月的销售总额(整数,输入-1退出):10000
请输入下一位销售员当月的销售总额(整数,输入-1退出):1699.88
请输入下一位销售员当月的销售总额(整数,输入-1退出):80086.98
请输入下一位销售员当月的销售总额(整数,输入-1退出):-1
录入已结束。

共录入了6位销售员的业绩:
总销售额为:103786.86美元,工资总额为:10539美元
工资分布如下表所示:
$200-299 1
$300-399 1
$400-499 1
$500-599 0
$600-699 0
$700-799 0
$800-899 0
$900-999 1
$1000以上 2



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
将一个 List<Map<String, String>> 类型的数据结构,其中包含键值对的字符串映射,存储到数据库中通常涉及几个步骤: 1. 数据模型设计:首先,你需要在数据库中定义一个适当的表结构来匹配这种数据结构。这可能是一个名为 `Commissions` 的表,其中包含一个字段,比如 `commission_records`,用来存储 JSON 形式的字符串,因为数据库中的大多数类型不适合直接存储 Map 对象。 2. 序列化:Map 对象是不可直接插入数据库的,所以你需要将其序列化为字符串。对于 Java,你可以使用 Gson 或者 Jackson 等库来完成 JSON 的转换。 ```java import com.google.gson.Gson; // 或者使用 Jackson import com.fasterxml.jackson.databind.ObjectMapper; ... List<Map<String, String>> commissions = ...; // 假设已经填充了数据 String jsonCommissions = new Gson().toJson(commissions); ``` 3. 插入数据:将序列化的 JSON 字符串插入到数据库表中。这里通常会使用 SQL 的 INSERT INTO 语句,如果是在关系型数据库如 MySQL、PostgreSQL 中,可能是这样的: ```sql INSERT INTO Commissions (commission_records) VALUES ('{...}'); ``` 如果你用的是支持 JSON 的非关系型数据库(如 MongoDB),则可以直接将 JSON 字符串插入到相应的文档中。 4. 避免性能问题:如果你的列表很大,一次性插入所有记录可能会导致性能下降。你可以考虑分批插入,或者使用事务来确保数据一致性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值