tianliangcsdn 2015-04-18 14:19 采纳率: 0%
浏览 1582

方法二只能精确的求一个数的整数次方,如何改?

double x,y,p; //求n次方(比较精确)
scanf("%lf%lf",&x,&y);
p=pow(x,y);
printf("%lf",p);
system("pause");
方法二
double i,n,sum=1.0,x; //求n次方(不精确)
scanf("%lf%lf",&x,&n);
for(i=0;i<n;i++)

{
sum*=x;
}

printf("%lf",sum);
system("pause");

方法二只能精确的求一个数的整数次方(方法一能),如何改才能精确地求一个数的小数次方?当然还是用for语句
eg:方法二 输入2 3 和2 2 .5其结果都是8.000000

  • 写回答

1条回答 默认 最新

  • threenewbee 2015-04-18 14:31
    关注

    方法二根本不能实现。

    如果你说的“方法二”不限定循环还是什么,而是不调用系统库函数,那么你可以求一个有理数(即可以转化为分数的数)次方。
    首先将有理数转化为分数,然后先求出分母次方,然后开N次方。
    开方可以使用牛顿迭代法。

    评论

报告相同问题?

悬赏问题

  • ¥20 指导如何跑通以下两个Github代码
  • ¥15 大家知道这个后备文件怎么删吗,为啥这些文件我只看到一份,没有后备呀
  • ¥15 C++为什么这个代码没报错运行不出来啊
  • ¥15 一道ban了很多东西的pyjail题
  • ¥15 关于#r语言#的问题:如何将生成的四幅图排在一起,且对变量的赋值进行更改,让组合的图漂亮、美观@(相关搜索:森林图)
  • ¥15 C++识别堆叠物体异常
  • ¥15 微软硬件驱动认证账号申请
  • ¥15 GPT写作提示指令词
  • ¥20 根据动态演化博弈支付矩阵完成复制动态方程求解和演化相图分析等
  • ¥15 华为超融合部署环境下RedHat虚拟机分区扩容问题