服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - C++另辟蹊径计算1到n的和

C++另辟蹊径计算1到n的和

2023-03-02 15:22Ggggggtm C/C++

从1加到100,高斯的故事,我们学过。今天,我们写一个程序来试试。首先,用笨方法。一个数一个数的加,我们一般人就是这样干的吗。在计算机程序里面,怎么办呢?1我们把求和的功能写成一个可以针对不同的N运用的,C++里面叫

注:满足题目要求的解法有递归实现的第三种、公式实现、C++调用构造函数累加法三种方法、

一、题目简单描述

最近看到一道很有趣的算法题,更像脑筋急转弯吧,如下图:

C++另辟蹊径计算1到n的和

我们可以看到,题目中给出的限制条件很多。先不管限制条件是什么,我们计算1到n的和无非就是用循环、递归、公式(等差数列)三类方法来计算。当然,循环实现很简单,这里就不再介绍。那么,不用循环怎么实现呢?我们先看用递归的方法。

二、递归实现

注意,我们先不管题目给出的限制条件,我们这里只限制不能用循环只用递归,看看都有哪些方法。

1、if…else…

用if…else…来判断递归的停止条件,相对也很容易,我们直接看代码。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
int Sum_Solution(int n)
{
    if (n == 1)
        return 1;
    return n + Sum_Solution(n - 1);
}
int main()
{
    int n = 0;
    scanf("%d", &n);
    int ret=Sum_Solution(n);
    printf("%d", ret);
    return 0;
}

2、三目运算符 ?:

在不用循环和if…else…的情况下还能怎么用呢?我们还可以想到三目运算符。其实三目运算符与if…else…思想大同小异,我们直接看代码。

?
1
2
3
4
5
6
7
8
9
10
11
12
int sum_solution(int n)
{
    return n==1?1:sum_solution(n-1)+n;
}
int main()
{
    int n = 0;
    scanf("%d", &n);
    int ret=Sum_Solution(n);
    printf("%d", ret);
    return 0;
}

3、逻辑与操作符 &&

难度加大,在不用循环和if…else…和三目运算符的情况下还能怎么用呢?好像不容易想出来其他方法了。其实当我们熟知逻辑与操作符(&&)的一个特性时,也就很用以做出来。当提到逻辑与操作符时,可能一时间想不到该怎么用。这时我们想想逻辑与操作符的性质。当两个条件同时为真时才为真,当第一个条件为假时,就不执行第二个条件了。这就是我们要抓住的点,来作为递归停止的条件。我们直接看代码。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
int Sum_Solution(int n )
{
    int sum=n;
        sum&&(sum+=Sum_Solution(n-1));
    return sum;
}
int main()
{
    int n = 0;
    scanf("%d", &n);
    int ret=Sum_Solution(n);
    printf("%d", ret);
    return 0;
}

其实这种解法就满足本题目的要求了。

三、公式实现

公式实现的方法有很多,用乘除法、循环都很容易实现。但是题目中还要求了不能够用乘除法,那怎么用公式实现呢?在这里用了一个很巧妙的方法,就是定义一个二维数组,数组存储的数据类型大小为一个字节,通过计算数组的大小,最后用右移操作符(>>)相当于除于2来实现。我们结合代码一起理解一下。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
int Sum_Solution(int n )
{
    char arr[n][n+1];
    return sizeof(arr)>>1;
}
int main()
{
    int n = 0;
    scanf("%d", &n);
    int ret=Sum_Solution(n);
    printf("%d", ret);
    return 0;
}

这种解法也满足题目的要求。

四、C++调用构造函数累加法

我们都知道C++在类和对象中,实例化对象都会调用构造函数。我们通过创建n个对象,同时设置成员变量为静态的,调用构造函数的累加法来实现。文字可能会有点不易理解,我们直接看代码。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
class sum
{
public:
    sum()
    {
        ret+=i;
        ++i;
    }
    static int GetRet()
    {
        return ret;
    }
private:
    static int ret;
    static int i;
};
int sum::ret=0;
int sum::i=1;
class Solution {
public:
    int Sum_Solution(int n)
    {
        sum a[n];
        return sum::GetRet();
    }
};

这种方法也是满足题目的要求的。

我个人感觉这道题目挺有趣的,就整理出来跟大家分享一下。当然,可能还有其它的解法,欢迎大家讨论。

希望本篇文章对你有所帮助,感谢观看ovo!

到此这篇关于C++另辟蹊径计算1到n的和的文章就介绍到这了,更多相关C++计算1到n的和内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/weixin_67596609/article/details/128437201

延伸 · 阅读

精彩推荐
  • C/C++C++ 虚函数表图文解析

    C++ 虚函数表图文解析

    最近学了设计模式中的简单工厂模式,对多态有了具体的认识。于是补了补多态、虚函数、虚函数表相关的知识,本文介绍了C++ 虚函数表,感兴趣的了解一...

    flight111111082021-11-05
  • C/C++C语言由浅入深了解变量的应用

    C语言由浅入深了解变量的应用

    这篇文章主要介绍了C语言的变量,变量是C语言语法和语义中一个很重要的知识点,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,...

    龟π气功10312022-11-25
  • C/C++C++类的大小介绍

    C++类的大小介绍

    这篇文章主要介绍了C++类的大小,在C++中,结构体和类的唯一区别就是结构体和类具有不同的默认访问控制属性,下面一起进入文章查看详细内容...

    学渣的C/C++3552022-02-22
  • C/C++C++调用C接口的实现示例

    C++调用C接口的实现示例

    这篇文章主要介绍了C++调用C接口的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着...

    DeRoy3932021-10-08
  • C/C++七大经典排序算法图解

    七大经典排序算法图解

    本文详细讲解了七大经典排序算法,文中通过示例代码介绍的非常详细。对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起...

    waywt17612022-03-11
  • C/C++C++超详细讲解模板的使用

    C++超详细讲解模板的使用

    这篇文章主要介绍了C++中模板(Template)的详解及其作用介绍,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参...

    努力变好的zz17892022-12-26
  • C/C++C++求所有顶点之间的最短路径(用Dijkstra算法)

    C++求所有顶点之间的最短路径(用Dijkstra算法)

    这篇文章主要为大家详细介绍了C++用Dijkstra算法求所有顶点之间的最短路径,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以...

    ChanJose4222021-09-02
  • C/C++C语言深入讲解栈与堆和静态存储区的使用

    C语言深入讲解栈与堆和静态存储区的使用

    对大多数C 语言初学者来说,堆栈却是一个很模糊的概念。堆栈是一种数据结构,一个在程序运行时用于存放的地方,相信这可能是很多初学者共同的认识...

    清风自在 流水潺潺4532022-11-10