剑指offer 面试题46:求1+2+...+n

题目:
求1+2+3+...+n,要求不能使用乘除法、for、while、if、else、switch、case等关键字及条件判断语句(A?B:C)

解法一:

class Solution {
    public:
        Solution() {
            ++n;
            sum += n;
        }

        static int getSum() {
            return sum;
        }

    private:
        static int n;
        static int sum;
};

int Solution::n = 0;
int Solution::sum = 0;

int main() {
    Solution *p = new Solution[n];
    delete[] p;
    cout << Sulotion::getSum() << endl;
}

解法二:

class A;
A* arr[2];

class A {
    public:
        virtual int sum(int n) {
            return 0;
        }
};

class B : public A {
    public:
        virtual int sum(int n) {
            return arr[!!n]->sum(n-1) + n;
        }
};

arr[0] = new A();
arr[1] = new B();

int val = arr[1]->sum(n);
delete []arr;

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 34,527评论 18 399
  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 12,869评论 0 33
  • 1 顺序语句 语句:使用分号分隔的代码称作为一个语句。 注意:没有写任何代码只是一个分号的时候,也是一条语句,...
    哈哈哎呦喂阅读 452评论 0 0
  • 临驹一中 青州实验 诸城繁华
    杨凯_6ff7阅读 254评论 0 0
  • 楔子 苏堤春晓 欲把西湖比西子,浓妆淡抹总相宜。站在苏堤上,看着一阵轻风吹过水面,我实在想不出来,苏东坡怎么会把西...
    醉死人阅读 349评论 0 0

友情链接更多精彩内容