zoukankan      html  css  js  c++  java
  • 【校招面试 之 剑指offer】第16题 数值的整数次方

    方法1:直接求解,但是要注意特殊情况的处理:即当指数为负,且底数为0的情况。

    #include<iostream>
    using namespace std;
    
    template<typename T>
    T myPow(T a, int m){
    	double base = 1;
    	int flag = (m < 0) ? -1 : 1;
    	int n = (m < 0) ? -m : m;
    
    	while(n > 0){
    		base = base * a;
    		n --;
    	}
    	if(flag == -1){
    		if(a != 0){
    			return (1/base);
    		}
    		cout<<"当指数为负时,0不能作为底数!"<<endl;
    		exit(-1);
    	}
    	return base;
    }
    int main(){
    
    	double a = 0;
    	// int a = 2;
    	int n = 10;
    	cout<<"求"<<a<<"的"<<n<<"次方为:"<<myPow(a, n)<<endl;
    	system("pause");
    	return 0;
    }
    

    方法2:可以归纳出下面的公式进行求解,使得循环次数大幅减小。也要注意特殊情况的处理:即当指数为负,且底数为0的情况。 

        an/2*an/2    n为偶数

    a=                                     

         a(n-1)/2*a(n-1)/2*a    n为奇数

    #include<iostream>
    using namespace std;
    
    // 符号处理(符号处理放在递归方法中出现问题,所以拿了出来)
    template<typename T>
    double myPow1(T a, int m){
    	int flag = (m < 0) ? -1 : 1;
    	int n = (m < 0) ? -m : m;
    	double result = myPow2(a, n, flag);
    	cout<<result<<endl;
    	if(flag == -1){
    		if(a != 0){
    			return (1/result);
    		}
    		cout<<"当指数为负时,0不能作为底数!"<<endl;
    		exit(-1);
    	}
    	return result;
    }
    template<typename T> T myPow2(T a, int n, int flag){ double result; if(n == 0){ return 0; } if(n == 1){ return a; } if(n%2 == 0){ result = myPow2(a, n/2, flag) * myPow2(a, n/2, flag); }else{ result = myPow2(a, (n-1)/2, flag) * myPow2(a, (n-1)/2, flag) * myPow2(a, 1, flag); } return result; } int main(){ double a = 0; // int a = 2; // int n = 8; int n = -10; cout<<"求"<<a<<"的"<<n<<"次方为:"<<myPow1(a, n)<<endl; system("pause"); return 0; }

      

  • 相关阅读:
    PHP页面静态化
    PHP实现单文件、多文件上传 封装 面向对象实现文件上传
    PHP MYSQL
    MySQL 数据表
    MySQL基础
    DOM事件处理程序-事件对象-键盘事件
    JS--显示类型转换Number—隐式类型转换
    JS的数据类型
    JS属性读写操作+if判断注意事项
    Javascript进阶篇——总结--DOM案例+选项卡效果
  • 原文地址:https://www.cnblogs.com/xuelisheng/p/9364478.html
Copyright © 2011-2022 走看看