当前位置: 代码迷 >> 综合 >> C++ 中abs,fabs,fabsf的使用及大数据的处理
  详细解决方案

C++ 中abs,fabs,fabsf的使用及大数据的处理

热度:40   发布时间:2023-11-21 20:25:58.0
  • abs( )主要用于对求整数的绝对值,在“stdlib.h”(或 )头文件里面
  • fabs( )主要是求精度要求更高的double ,float 型的绝对值
  • fabsf(float i); //处理float类型的取绝对值(功能可以被double覆盖)
  • 通过下面代码测试发现两点问题1:abs()也可对小数取绝对;2:abs(),fabs()的返回值默认为5位小数,如要保留更多位则要用printf()!
#include<iostream>
#include<algorithm> 
#include<cmath>
using namespace std;
int main()
{
    int x = -5;double y = -1.5555555;cout<<abs(x)<<endl;cout<<abs(y)<<endl;cout<<fabs(y)<<endl;printf("%.7lf",fabs(y)); return 0;
}
结果:
5
1.55556
1.55556
1.5555555
------------
  • 关于大数据的处理方法(大到会爆的那种)
    1:要算出精确结果时 用高精度 + - * /
    2:只需要大概的结果时 取对数进行运算
    下面贴出一道题:
    郑轻2678
    answer:
#include<iostream>
#include<algorithm> 
#include<cmath>
using namespace std;
int main()
{
    int n, m, num;while(cin>>n>>m){
    double sum1 = 0, sum2 = 0;//进行对数运算要用double定义 for(int i = 1; i<=n; i++){
    cin>>num;sum1 += log(num); //log()默认底数为e }for(int i = 1; i<=m; i++){
    cin>>num;sum2 += log(num);}if(fabs(sum1-sum2)<=1e-8) //因为sum1与sum2不会相等,//之可能会近似接近所以要先判断两者相等的情况,当两者的差值小于1e-8即视为相等 cout<<"lgc:玩什么原神,还不快点给我过来训练!"<<endl;else if(sum1<sum2)cout<<"zjl学姐nb"<<endl;else cout<<"sj学姐nb"<<endl;}return 0;
}