美文网首页
100000567 - 《算法笔记》2.3小节——C/C++快速

100000567 - 《算法笔记》2.3小节——C/C++快速

作者: 广陵周惊蛰 | 来源:发表于2020-05-14 11:17 被阅读0次

    作业比赛编号 : 100000567 - 《算法笔记》2.3小节——C/C++快速入门->选择结构

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

    [命题人 : 外部导入]
    时间限制 : 1.000 sec 内存限制 : 12 MB

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

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

    输入

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

    输出

    分行输出两个根如下(注意末尾的换行):
    
    r1=第一个根
    
    r2=第二个根
    

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

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

    No real roots!
    

    样例输入 Copy

    1 2 3
    

    样例输出 Copy

    No real roots!
    

    C:

    #include <stdio.h>
    #include <math.h>
    int main(){
        double a,b,c,d,r1,r2;
        scanf("%lf,%lf,%lf",&a,&b,&c);
        d=b*b-4*a*c;
        r1=(-b+sqrt(d))/2*a;
        r2=-(b-sqrt(d))/2*a; 
        if(a!=0&&d>0)
            printf("r1=%7.2lf\nr2=%7.2lf",r1,r2);
        else 
            printf("No real roots!\n");
        return 0;
    } 
    

    C++:

    #include <iostream>
    #include <math.h>
    using namespace std;
    int main(){
        double a,b,c,d,r1,r2;
        scanf("%lf,%lf,%lf",&a,&b,&c);
        d=b*b-4*a*c;
        r1=(-b+sqrt(d))/2*a;
        r2=-(b-sqrt(d))/2*a; 
        if(a!=0&&d>0)
            printf("r1=%7.2lf\nr2=%7.2lf",r1,r2);
        else 
            printf("No real roots!\n");
        return 0;
    }
    

    或C++:

    #include <iostream>
    #include <math.h>
    #include <iomanip>
    using namespace std;     
    int main(){
        double a,b,c,d,r1,r2;
        cin>>a>>b>>c;
        d=b*b-4*a*c;
        r1=(-b+sqrt(d))/2*a;
        r2=-(b-sqrt(d))/2*a; 
        if(a!=0&&d>0){
            cout <<setiosflags(ios::fixed);
            cout<<setprecision(2);//输出小数点后2位
            cout<<"r1=";
            cout.width(7);
            cout<<r1<<endl<<"r2=";
            cout.width(7);
            cout<<r2;
        }
        else 
            cout<<"No real roots!<<endl;
        return 0;
    }
    

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

    [命题人 : 外部导入]
    时间限制 : 1.000 sec 内存限制 : 12 MB

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

    输入
    用空格分隔的两个实数。

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

    样例输入 Copy
    3.6 -2.3

    样例输出 Copy
    -2.30 3.60

    C:

    #include <stdio.h>
    int main(){
        float a,b;
        scanf("%f %f",&a,&b);
        if(a>=b)
            printf("%.2f %.2f\n",b,a);  
        else 
            printf("%.2f %.2f\n",a,b);
    }
    

    C++:

    #include <iostream>
    #include <iomanip>
    using namespace std;     
    int main(){
        float a,b;
        cin>>a>>b;
        cout <<setiosflags(ios::fixed);
        cout<<setprecision(2);//输出小数点后2位
        if(a>=b){
            cout<<b<<" "<<a<<endl;
        }
        else 
            cout<<a<<" "<<b<<endl;
        return 0;
    }
    

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

    [命题人 : 外部导入]
    时间限制 : 1.000 sec 内存限制 : 12 MB

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

    末尾输出换行。

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

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

    样例输入 Copy
    3 7 1

    样例输出 Copy
    1.00 3.00 7.00

    C:

    #include <stdio.h>
    int main(){
        float a,b,c,temp;
        scanf("%f %f %f",&a,&b,&c);
    
        if(c<b){
            temp=b;
            b=c;
            c=temp;
        }
        if(b<a){
            temp=a;
            a=b;
            b=temp;
        }
        
        printf("%.2f %.2f %.2f\n",a,b,c);
    }
    

    C++:

    #include <iostream>
    #include <iomanip>
    using namespace std;     
    int main(){
        float a,b,c,temp;
        cin>>a>>b>>c;
        cout<<setiosflags(ios::fixed);
        cout<<setprecision(2);//输出小数点后2位
        
        if(c<b){
            temp=b;
            b=c;
            c=temp;
        }
        if(b<a){
            temp=a;
            a=b;
            b=temp;
        }
        cout<<a<<" "<<b<<" "<<c<<endl;
        return 0;
    }
    

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

    [命题人 : 外部导入]
    时间限制 : 1.000 sec 内存限制 : 12 MB

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

    输入
    以空格分割的三个整数。

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

    样例输入 Copy
    1 3 2

    样例输出 Copy
    3

    C:

    #include <stdio.h>
    int main(){
        int max,a,b,c;
        scanf("%d %d %d",&a,&b,&c);
        max=a;
        if(b>max)
            max=b;
        if(c>max)
            max=c;
        printf("%d\n",max);
    }
    

    C++:

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

    问题 E: 习题4-10-1 奖金计算

    [命题人 : 外部导入]
    时间限制 : 1.000 sec 内存限制 : 12 MB

    题目描述

    某企业发放的奖金根据利润提成。利润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位小数,末尾换行。

    样例输入 Copy
    1050

    样例输出 Copy
    105.00

    C:

    #include <stdio.h>
    #define w 100000
    int main(){
        double p,b;//profit,bonus
        scanf("%lf",&p);
        if  (p>1*w){
            if(p>2*w){
                if(p>4*w){
                    if(p>6*w){
                        if(p>1*w){
                            b=p*0.1+(p-1*w)*0.075+(p-2*w)*0.05+(p-4*w)*0.03+(p-6*w)*0.015+(p-10*w)*0.01;
                        }else b=p*0.1+(p-1*w)*0.075+(p-2*w)*0.05+(p-4*w)*0.03+(p-6*w)*0.015;
                    }else b=p*0.1+(p-1*w)*0.075+(p-2*w)*0.05+(p-4*w)*0.03;
                }else b=p*0.1+(p-1*w)*0.075+(p-2*w)*0.05;
            }else b=p*0.1+(p-1*w)*0.075;
        }else b=p*0.1;
        printf("%.2lf",b);
        return 0;
    }
    

    C++:

    #include <iostream>
    #include <iomanip>
    using namespace std; 
    #define w 100000
    
    int main(){
        double p,b;//profit,bonus
        cin>>p;
        if  (p>1*w){
            if(p>2*w){
                if(p>4*w){
                    if(p>6*w){
                        if(p>1*w){
                            b=p*0.1+(p-1*w)*0.075+(p-2*w)*0.05+(p-4*w)*0.03+(p-6*w)*0.015+(p-10*w)*0.01;
                        }else b=p*0.1+(p-1*w)*0.075+(p-2*w)*0.05+(p-4*w)*0.03+(p-6*w)*0.015;
                    }else b=p*0.1+(p-1*w)*0.075+(p-2*w)*0.05+(p-4*w)*0.03;
                }else b=p*0.1+(p-1*w)*0.075+(p-2*w)*0.05;
            }else b=p*0.1+(p-1*w)*0.075;
        }else b=p*0.1;
        cout<<setiosflags(ios::fixed);
        cout<<setprecision(2);//输出小数点后2位
        cout<<b;
        return 0;
    }
    
    image.png

    相关文章

      网友评论

          本文标题:100000567 - 《算法笔记》2.3小节——C/C++快速

          本文链接:https://www.haomeiwen.com/subject/xanixhtx.html