《算法笔记》2.3小节

接上....前面这几部分做的有点赶...变量名起的有点随意QAQ...哪天有空回炉重造一下

 

问题 A: 例题4-1 一元二次方程求根

题目描述

求一元二次方程ax2+bx+c=0的根,三个系数a, b, c由键盘输入,且a不能为0,但不保证b2-4ac>0。

程序中所涉及的变量均为double类型。

输入

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

输出

分行输出两个根如下(注意末尾的换行):

r1=第一个根

r2=第二个根

结果输出时,宽度占7位,其中小数部分2位。

如果方程无实根,输出一行如下信息(注意末尾的换行):

No real roots!

样例输入

1 2 3

样例输出

No real roots!
#include<iostream>
#include<cmath>
#include <iomanip> 
using namespace std;
int main()
{
     
double a,b,c,r1,r2;
cin>>a>>b>>c;
r1=(-b+sqrt(b*b-4*a*c))/(2*a); 
r2=(-b-sqrt(b*b-4*a*c))/(2*a); 
if(b*b-4*a*c>=0)
{
    cout<<"r1="<<setw(7)<<setiosflags(ios::fixed)<<setprecision(2)<<r1
    <<endl<<"r2="<<setw(7)<<setiosflags(ios::fixed)<<setprecision(2)<<r2;
}
else
    cout<<"No real roots!"<<endl;
 
return 0;
 
} 

问题 B: 例题4-2 比较交换实数值

题目描述

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

输入

用空格分隔的两个实数。

输出

从小到大输出这两个实数,中间以空格来分隔,小数在前,大数在后。

小数点后保留2位小数。

末尾输出换行符。

样例输入

3.6 -2.3

样例输出

-2.30 3.60
#include<iostream>
#include <iomanip>
using namespace std;
int main()
{
     
double a,b,min,max;
cin>>a>>b;
if(a>b)
{
    max=a;
    min=b;
}
else
{
    max=b;
    min=a;
}
 
cout<<setiosflags(ios::fixed)<<setprecision(2)<<min<<" "<<
    setiosflags(ios::fixed)<<setprecision(2)<<max<<endl;
 
return 0;
 
} 

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

题目描述

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

末尾输出换行。

输入

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

输出

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

注意末尾的换行。

样例输入

3 7 1

样例输出

1.00 3.00 7.00
    #include<iostream>
    #include <iomanip>
    using namespace std;
    int main()
    {
         
    double a,b,c,temp;
    cin>>a>>b>>c;
    if(a>b)
    {   
        temp=a;
        a=b;
        b=temp;
    }
    if(a>c)
    {
        temp=a;
        a=c;
        c=temp;
    }
    if(b>c)
    {
        temp=b;
        b=c;
        c=temp;
    }
     
    cout<<setiosflags(ios::fixed)<<setprecision(2)<<a<<" "<<
        setiosflags(ios::fixed)<<setprecision(2)<<b<<" "<<
        setiosflags(ios::fixed)<<setprecision(2)<<c<<endl;
     
    return 0;
     
    } 

问题 D: 习题4-4 三个整数求最大值

题目描述

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

输入

以空格分割的三个整数。

输出

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

样例输入

1 3 2

样例输出

3
    #include<iostream>
    #include <iomanip>
    using namespace std;
    int main()
    {
         
    int a,b,c,temp;
    cin>>a>>b>>c;
    if(a>b)
    {   
        temp=a;
        a=b;
        b=temp;
    }
    if(a>c)
    {
        temp=a;
        a=c;
        c=temp;
    }
    if(b>c)
    {
        temp=b;
        b=c;
        c=temp;
    }
     
    cout<<c<<endl;
     
    return 0;
     
    } 
 

直接复制上一题的代码...⊙﹏⊙‖∣

问题 E: 习题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位小数,末尾换行。

样例输入

1050

样例输出

105.00

 

    #include<iostream>
    #include <iomanip>
    using namespace std;
    int main()
    {
         
    double l,a=0;
    cin>>l;
    if(l<=100000)
    {   
        a+=l*0.1;
    }
    else if(l>100000&&l<=200000)
    {
        a+=10000+(l-100000)*0.075;
    }
    else if(l>200000&&l<=400000)
    {
        a+=17500+(l-200000)*0.05;
    }
    else if(l>400000&&l<=600000)
    {
        a+=27500+(l-400000)*0.03;
    }
    else if(l>600000&&l<=1000000)
    {
        a+=33500+(l-600000)*0.015;
    }
    else
    {
        a+=39500+(l-1000000)*0.01;
    }
    cout<<setiosflags(ios::fixed)<<setprecision(2)<<a<<endl;
     
    return 0;
     
    } 

眼睛都花了..以前的噩梦..现在也是

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

云无心鸟知还

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值