3、求方程

该文介绍了一个C++程序,用于计算一元二次方程ax^2+bx+c=0的根,其中a、b、c由用户输入。程序利用了math.h库中的pow函数来计算平方根,并确保当b^2-4ac大于0时能正确求解两个根,结果保留两位小数。同时,文章还讲解了pow函数的基本用法和printf格式化输出的相关知识。
摘要由CSDN通过智能技术生成

#include<iostream>
#include<math.h>
using namespace std;
//编写程序求方程ax2+bx+c=0的根,a、b、c的值由键盘输入,假设b2-4ac>0
//3个整数a b c,以一个空格分隔
//两个根,大数在前,小数在后
//输出时保留两位小数。
int main(){
int a,b,c;
double d1,d2;
cin>>a>>b>>c;
d1=((-1.0*b)+pow(1.00*b*b-4.00*a*c,1.0/2))/(2*a);
d2=((-1.0*b)-pow(1.00*b*b-4.00*a*c,1.0/2))/(2*a);
if(d1<d2){
  double temp=d1;
  d1=d2;
  d2=temp;}
printf("%.2f%s%.2f",d1," ",d2);
}

pow函数

1.首先使用pow函数必须要加头文件 :

#include<math.h>

pow() 函数用来求 x 的 y 次幂(次方),x、y及函数值实际上为double型 ,其在使用中的原型为:double pow(double x, double y);

2.pow()用来计算以x 为底的 y 次方值,然后将结果返回。设返回值为 ret

则 ret = x^y


#include<stdio.h>
#include<math.h>
int main()
{
    int a,b,ret;
    scanf("%d,%d", &a, &b);
    ret = pow(a,b);    //求出a的b次方
    printf("%d", ret);
    return 0;
}

所以在使用pow函数时,要注意底数和指数数字的正负,不要违反基本的数学常识

%d 十进制有符号整数

%u 十进制无符号整数

%f 浮点数

%s 字符串

%c 单个字符

%p 指针的值

%e 指数形式的浮点数

%x, %X 无符号以十六进制表示的整数

%0 无符号以八进制表示的整数

%g 自动选择合适的表示法

%.nf保留n位小数

%s字符串

在"%"和字母之间插进数字表示最大场宽。

-在"%"和字母之间加小写字母l, 表示输出的是长型数。

%ld 表示输出long整数

%lf 表示输出double浮点数

如果字符串的长度、或整型数位数超过说明的场宽, 将按其实际长度输出。

  • 但对浮点数, 若整数部分位数超过了说明的整数位宽度, 将按实际整数位输出;

  • 若小数部分位数超过了说明的小数位宽度, 则按说明的宽度以四舍五入输出。

  • 另外, 若想在输出值前加一些0, 就应在场宽项前加个0。

  • 例如: %04d 表示在输出一个小于4位的数值时, 将在前面补0使其总宽度为4位。
    如果用浮点数表示字符或整型量的输出格式, 小数点后的数字代表最大宽度, 小数点前的数字代表最小宽度。

  • 例如: %6.9s 表示显示一个长度不小于6且不大于9的字符串。若大于9, 则第9个字符以后的内容将被删除。
    可以控制输出左对齐或右对齐, 即在"%“和字母之间加入一个”-" 号可说明输出为左对齐, 否则为右对齐。

  • 例如: %-7d 表示输出7位整数左对齐
    %-10s 表示输出10个字符左对齐

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值