查看: 834| 回复: 0
跳转到指定楼层
上一主题 下一主题
收起左侧

请问 调用函数和直接写过程 这两种复杂度相同吗

全局:

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看附件。没有帐号?注册账号

x
如题,例子代码如下:
1.不调用函数:class Solution {
public:
    double myPow(double x, int n) {
        if(x==0)return 0;
        if(n==0)return 1;
        if(n==1)return x;
        int m=n;
        if(n<0) m=-m;
        double a=x;
         vector<int>way;
        while(m!=1){
            if(m/2==0){m=m/2;way.push_back(1);}
            else {m=m-1;way.push_back(0);}
        }
        for(int i=0;i<way.size();i++){
            if(way[i]==1)x=x*x;
            else x=x*a;
        }
        if(n<0)return 1/x;
        else return x;
        
    }
};

2.调用函数:
double findPow(double x, int n, double a) {
                if (n == 1)return x;
                vector<int>way;
                while (n != 1) {
                        if (n / 2 == 0) { n = n / 2; way.push_back(1); }
                        else { n = n - 1; way.push_back(0); }
                }
                for (int i = 0; i < way.size(); i++) {
                        if (way[i] == 1)x = x * x;
                        else x = x * a;
                }
                return x;

        }
        double myPow(double x, int n) {
                if (x == 0)return 0;
                double a = x;
                if (n >= 1)return findPow(x, n, a);
                else return 1 / findPow(x, -n, a);

        }

上一篇:leet 43 求教
下一篇:请大神比较这两种算法复杂度区别
您需要登录后才可以回帖 登录 | 注册账号
隐私提醒:
  • ☑ 禁止发布广告,拉群,贴个人联系方式:找人请去🔗同学同事飞友,拉群请去🔗拉群结伴,广告请去🔗跳蚤市场,和 🔗租房广告|找室友
  • ☑ 论坛内容在发帖 30 分钟内可以编辑,过后则不能删帖。为防止被骚扰甚至人肉,不要公开留微信等联系方式,如有需求请以论坛私信方式发送。
  • ☑ 干货版块可免费使用 🔗超级匿名:面经(美国面经、中国面经、数科面经、PM面经),抖包袱(美国、中国)和录取汇报、定位选校版
  • ☑ 查阅全站 🔗各种匿名方法

本版积分规则

>
快速回复 返回顶部 返回列表