《算法笔记》例题解析 第2章C++快速入门--3选择结构(5题)2021-02-18

1.例题4-1 一元二次方程求根

题目描述

求一元二次方程ax ^2+bx+c=0的根,三个系数a, b, c由键盘输入,且a不能为0,但不保证b ^2-4ac>0。
程序中所涉及的变量均为double类型。

输入

以空格分隔的一元二次方程的三个系数,双精度double类型

输出

分行输出两个根如下(注意末尾的换行):
r1=第一个根
r2=第二个根
结果输出时,宽度占7位,其中小数部分2位。
如果方程无实根,输出一行如下信息(注意末尾的换行):
No real roots!

代码
#include <iostream>
#include <stdio.h>
#include <math.h>
using namespace std;
int main(){
	double a, b, c;
	double m, n, k;
	scanf_s("%lf%lf%lf",&a,&b,&c);
	if (!a) {
		printf("wrong");
	}
	else {
		k = b * b - (double)4 * a*c;
		if (k < 0) {
			printf("No real roots!\n");
		}
		else {
			m = ((-b) + sqrt(k)) / ((double)2 * a);//计算第一个结果 
			n = ((-b) - sqrt(k)) / ((double)2 * a);//计算第二个结果
			printf("r1=%7.2f\n",m);
			printf("r2=%7.2f\n",n);
		  }
	}
	return 0;
}

2.例题4-1 一元二次方程求根

题目描述

从键盘输入2个实数,按照代数值由小到大的顺序输出这两个数。

输入

用空格分隔的两个实数。

输出

从小到大输出这两个实数,中间以空格来分隔,小数在前,大数在后。
小数点后保留2位小数。
末尾输出换行符。

代码
#include <iostream>
#include <stdio.h>
using namespace std;
int main()
{
	double a, b;
	scanf_s("%lf%lf",&a,&b);
	if (a > b) {
		double c = a;
		a = b;
		b = c;
	}
	printf("%.2f %.2f\n",a,b);
	return 0;
}

3.例题4-3 比较交换3个实数值,并按序输出

题目描述

从键盘输入3个实数a, b, c,通过比较交换,将最小值存储在变量a中,最大值存储在变量c中,中间值存储在变量b中,并按照从小到大的顺序输出这三个数a, b, c。
末尾输出换行。

输入

输入以空格分隔的三个实数

输出

按照从小到大的顺序输出这三个实数,中间以空格分隔,最小值在前,最大值在后。小数点后保留2位小数。
注意末尾的换行。

代码
#include <iostream>
#include <stdio.h>
#include <math.h>
using namespace std;
void swap (double &a, double &b) {
	double c = a;
	a = b;
	b = c;
}
int main()
{
	double a, b, c;
	scanf_s("%lf%lf%lf",&a,&b,&c);
	//冒泡排序思想
	//一趟排序
	if (c < b) {
		swap(c, b);
		if (b < a) {
			swap(a,b);
		}
	}
	//二趟排序
	if (c < b) {
		swap(c, b);
	}
	printf("%.2f %.2f %.2f",a, b, c);
	return 0;
}

4.习题4-4 三个整数求最大值

题目描述

有3个整数a, b, c,由键盘输入,输出其中最大的数。

输入

以空格分割的三个整数。

输出

三个数中的最大值,末尾换行。

代码
#include <iostream>
#include <stdio.h>
#include <math.h>
using namespace std;
int main()
{
	int a, b, c;
	scanf_s("%d%d%d",&a,&b,&c);

	if (a>=b&&a>=c) {
		printf("%d\n",a);
	}else if (b >= c) {
		printf("%d\n", b);
	}
	else {
		printf("%d\n", c);
	}
	return 0;
	}

5 习题4-10-1 奖金计算

题目描述

某企业发放的奖金根据利润提成。利润I低于或等于100000时,奖金可提10%;利润高于100000元,低于200000元(100000<I<=200000)时,低于100000元的部分仍按10%提成,高于100000元的部分提成比例为7.5%;200000<I<=400000时,低于200000元的部分仍按上述方法提成(下同),高于200000元的部分按5%提成;400000<I<=600000元时,高于400000元的部分按3%提成;600000<I<=1000000时,高于600000元的部分按1.5%提成;I>1000000元时,超过1000000元的部分按1%提成。

从键盘输出当月利润I,求应发奖金数,奖金精确到分。

要求用if语句实现。

输入

企业利润,小数,双精度double类型

输出

应发奖金数,保留2位小数,末尾换行。

代码
#include <iostream>
#include <stdio.h>
#include <math.h>
using namespace std;
int main(){
	double l;//利润
	double b;//奖金
	scanf_s("%lf",&l);
	if (l <= 100000) {
		b = l * 0.1 ;
	}
	else if (100000 < l&&l <= 200000) {
		b = (l-100000)*0.075+10000;
	}
	else if (200000 < l&&l <= 400000) {
		b = (l-200000)*0.05+7500+10000;
	}
	else if (400000 < l&&l <= 600000) {
		b = (l - 400000)*0.03 + 10000 + 7500 + 10000;
	}
	else if (600000<l&&l<=1000000) {
		b = (l - 600000)*0.015 + 6000 + 10000 + 7500 + 10000;
	}
	else if (l > 1000000) {
		b = (l - 1000000)*0.01 + 6000 + 6000 + 10000 + 7500 + 10000;
	}
	printf("%.2f\n",b);
	return 0; 
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值