目录
【1】三位数字重组问题
题目:有 1、2、3、4 四个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?
分析:分别把1,2,3,4放在个位、十位和百位,用嵌套循环即可解决。注意要求无重复数字,所以还要进行if条件判断,算有几个需要用一个计数器。
#include <stdio.h>
int main()
{
int a = 0; //计数器,用来算有几个
//百位
for (int i = 1; i <= 4; i++)
{
//十位
for (int j = 1; j <= 4; j++)
{
//个位
for (int k = 1; k <= 4; k++)
{
//无重复数字
if (i != j && j != k && i!=k)
{
a++;
printf("%d%d%d\t", i, j, k);
}
}
}
}
printf("\n一共能组成%d个三位数", a);
return 0;
}
【2】奖金利润问题
题目:企业发放的奖金根据利润提成。
- 利润(I)低于或等于10万元时,奖金可提10%;
- 利润高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可提成7.5%;
- 20万到40万之间时,高于20万元的部分,可提成5%;
- 40万到60万之间时高于40万元的部分,可提成3%;
- 60万到100万之间时,高于60万元的部分,可提成1.5%;
- 高于100万元时,超过100万元的部分按1%提成。
从键盘输入当月利润I,求应发放奖金总数?
分析:需要设置10万,20万,40万,60万和100万这几个分界点,再通过if可以方便计算。
奖金:bonus
#include <iostream>
using namespace std;
int main()
{
double l;
double bonus1, bonus2, bonus4, bonus6, bonus10, bonus;
cout << "当月利润:" << endl;
cin >> l;
bonus1 = 100000 * 0.1;
bonus2 = bonus1 + 100000 * 0.75;
bonus4 = bonus2 + 200000 * 0.05;
bonus6 = bonus4 + 200000 * 0.03;
bonus10 = bonus6 + 400000 * 0.015;
if (l <= 100000) {
bonus = l * 0.1;
}
else if (l <= 200000) {
bonus = bonus1 + (l - 100000) * 0.075;
}
else if (l <= 400000) {
bonus = bonus2 + (l - 200000) * 0.05;
}
else if (l <= 600000) {
bonus = bonus4 + (l - 400000) * 0.03;
}
else if (l <= 1000000) {
bonus = bonus6 + (l - 600000) * 0.015;
}
else if (l > 1000000) {
bonus = bonus10 + (l - 1000000) * 0.01;
}
cout << "应发放奖金:" << bonus << endl;
system("pause");
return 0;
}