欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

C语言程序设计100例之(2):一元二次方程

程序员文章站 2023-08-31 09:29:27
例2 一元二次方程 【题目描述】 输入系数a、b和c,求方程ax2+bx+c=0的根。 【输入格式】 输入数据有多组。每组数据包括三个系数a,b,c。当a=0时,输入数据结束。 【输出格式】 输出方程的根,格式参见输出样例,保留到小数点后2位。 【输入样例】 1 2 1 1.0 -4.0 3.0 1 ......

例2   一元二次方程

【题目描述】

输入系数a、b和c,求方程ax2+bx+c=0的根。

【输入格式】

输入数据有多组。每组数据包括三个系数a,b,c。当a=0时,输入数据结束。

【输出格式】

输出方程的根,格式参见输出样例,保留到小数点后2位。

【输入样例】

1 2 1

1.0 -4.0 3.0

1.5 2.0 1.5

0 0 0

【输出样例】

x1=x2=-1.00

x1=3.00,x2=1.00

x1=-0.67+0.75i,x2=-0.67-0.75i

        (1)编程思路。

        根据输入的系数a,可以分为a不等于0和a等于0两种情况。

C语言程序设计100例之(2):一元二次方程

        当a==0时,结束输入计算。

        程序可以写成if的嵌套结构。

        (2)源程序。

#include <stdio.h>

#include <math.h>

int main()

{

    double a,b,c,dlt,real,imag,x1,x2;

    while (1)

    {

        scanf("%lf%lf%lf",&a,&b,&c);

        if (a==0)  break;

              dlt=b*b-4*a*c;

              if (dlt>0)

              {

                  x1=(-b+sqrt(dlt))/(2*a);

                  x2=(-b-sqrt(dlt))/(2*a);

            printf("x1=%.2f,x2=%.2f\n",x1,x2);

              }

        else if (dlt==0)

              {

                     x1=x2=(-b)/(2*a);

                     printf("x1=x2=%.2f\n",x1);

              }

        else

              {

                  real=(-b)/(2*a);

                  imag=sqrt(-dlt)/(2*a);

            printf("x1=%.2f+%.2fi,x2=%.2f-%.2fi\n",real,imag,real,imag);

              }

       }

    return 0;

}

 

习题2

2-1  三角形面积

【题目描述】

任意输入三条边(a,b,c实型),若能构成三角形,则计算并输出其面积,否则输出标志“no triangle!”。

三角形面积计算公式:

       C语言程序设计100例之(2):一元二次方程

 【输入格式】

输入数据有多组。每组数据包括三个数a,b,c,代表三角形的三个边长。当a=0时,输入数据结束。

【输出格式】

输出三角形的面积,保留到小数点后2位。或者no triangle!信息,若给定的三个边长值不能构成一个三角形。

【输入样例】

3 4 5

6.0 6.0 6.0

1 1 3

0 0 0

【输出样例】

6.00

15.59

no triangle!

        (1)编程思路。

输入的a、b、c三个数,只有当a+b>c、a+c>b和b+c>a同时满足时,才能构成一个三角形。因此,用选择结构

if (a+b>c && a+c>b && b+c>a)

      {   计算三角形面积并输出; }

      else

      {   输出不能构成三角形的提示信息;  }

      (2)源程序。

#include <stdio.h>

#include <math.h>

int main()

{

    float a,b,c,t,s;

    while (1)

    {

        scanf("%f%f%f",&a,&b,&c);

        if (a==0) break;

        if (a+b>c && a+c>b && b+c>a)

        {

           t=(a+b+c)/2.0;

           s=sqrt(t*(t-a)*(t-b)*(t-c));

           printf("%.2f\n",s);

        }

        else

           printf("no triangle!\n");

       }

    return 0;

}

2-2  小玉家的电费

        本题选自洛谷题库 (https://www.luogu.org/problem/p1422)。

【题目描述】

夏天到了,各家各户的用电量都增加了许多,相应的电费也交的更多了。小玉家今天收到了一份电费通知单。小玉看到上面写:据闽价电[2006]27号规定,月用电量在150千瓦时及以下部分按每千瓦时0.4463元执行,月用电量在151~400千瓦时的部分按每千瓦时0.4663元执行,月用电量在401千瓦时及以上部分按每千瓦时0.5663元执行;小玉想自己验证一下,电费通知单上应交电费的数目到底是否正确呢。请编写一个程序,已知用电总计,根据电价规定,计算出应交的电费应该是多少。

【输入格式】

输入一个整数,表示用电总计(单位以千瓦时计),不超过10000。

【输出格式】

输出一个数,保留到小数点后1位(单位以元计,保留到小数点后1位)。

【输入样例】

267

【输出样例】

121.5

        (1)编程思路。

        根据月用电量x的情况,其计费规则分为三个梯度。

       在第一梯度(x<=150),电费y = 第一梯度单位电费*用电量=0.4463*x;

        在第二梯度(150<x<=400),电费y=第二梯度部分用电*第二梯度部分单位电费+在第一梯度用电*第一梯度单位电费 =(x-150)*0.4663+150*0.4463。

        在第三梯度(x>400),电费y=第三梯度部分用电*第三梯度部分单位电费+第二梯度部分用电*第二梯度部分单位电费+在第一梯度用电*第一梯度单位电费 =(x-400)*0.5663 +250*0.4663+150*0.4463。

        一个简单的多分支结构即可解决。

        (2)源程序。

#include  <stdio.h>

int main()

{

    int x;

       double y;

       scanf("%d",&x);

       if (x<=150) y=0.4463*x;

       else if (x<=400) y=150*0.4463+(x-150)*0.4663;

       else y=150*0.4463+250*0.4663+(x-400)*0.5663;

       printf("%.1lf\n",y);

       return 0;

}

 

2-3  p1909 买铅笔

         本题选自洛谷题库 (https://www.luogu.org/problem/p1909)。

【题目描述】

p老师需要去商店买n支铅笔作为小朋友们参加noip的礼物。她发现商店一共有 3种包装的铅笔,不同包装内的铅笔数量有可能不同,价格也有可能不同。为了公平起 见,p老师决定只买同一种包装的铅笔。

商店不允许将铅笔的包装拆开,因此p老师可能需要购买超过n支铅笔才够给小朋友们发礼物。

现在p老师想知道,在商店每种包装的数量都足够的情况下,要买够至少n支铅笔最少需要花费多少钱。

【输入格式】

第一行包含一个正整数n,表示需要的铅笔数量。

接下来三行,每行用2个正整数描述一种包装的铅笔:其中第1个整数表示这种包装内铅笔的数量,第2个整数表示这种包装的价格。

保证所有的7个数都是不超过10000的正整数。

【输出格式】

1个整数,表示p老师最少需要花费的钱。

【输入样例】

57

2 2

50 30

30 27

【输出样例】

54

           (1)编程思路。

         设p老师需要购买的铅笔数为n,某种包装内铅笔的数量为a,这种包装的价格为b。p老师需要购买某种包装铅笔的包装数为c。

         显然,若n能整除a,则c=n/a;否则c=n/a+1。

         求三种包装的c*b的最小值即可。

  (2)源程序。

#include <stdio.h>

int main()

{

    int n,a,b,c,i,min;

    scanf("%d",&n);

    scanf("%d%d",&a,&b);

       if (n%a==0) c=n/a;

       else c=n/a+1;

    min=c*b;

       for (i=1;i<=2;i++)

       {

           scanf("%d%d",&a,&b);

         if (n%a==0) c=n/a;

           else c=n/a+1;

        if (min>c*b) min=c*b;

       }

       printf("%d\n",min);

       return 0;

}