欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++另辟蹊徑計(jì)算1到n的和

 更新時間:2023年02月13日 10:12:30   作者:Ggggggtm  
從1加到100,高斯的故事,我們學(xué)過。今天,我們寫一個程序來試試。首先,用笨方法。一個數(shù)一個數(shù)的加,我們一般人就是這樣干的嗎。在計(jì)算機(jī)程序里面,怎么辦呢?1我們把求和的功能寫成一個可以針對不同的N運(yùn)用的,C++里面叫函數(shù)

注:滿足題目要求的解法有遞歸實(shí)現(xiàn)的第三種、公式實(shí)現(xiàn)、C++調(diào)用構(gòu)造函數(shù)累加法三種方法、

一、題目簡單描述

最近看到一道很有趣的算法題,更像腦筋急轉(zhuǎn)彎吧,如下圖:

我們可以看到,題目中給出的限制條件很多。先不管限制條件是什么,我們計(jì)算1到n的和無非就是用循環(huán)、遞歸、公式(等差數(shù)列)三類方法來計(jì)算。當(dāng)然,循環(huán)實(shí)現(xiàn)很簡單,這里就不再介紹。那么,不用循環(huán)怎么實(shí)現(xiàn)呢?我們先看用遞歸的方法。

二、遞歸實(shí)現(xiàn)

注意,我們先不管題目給出的限制條件,我們這里只限制不能用循環(huán)只用遞歸,看看都有哪些方法。

1、if…else…

用if…else…來判斷遞歸的停止條件,相對也很容易,我們直接看代碼。

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、三目運(yùn)算符 ?:

在不用循環(huán)和if…else…的情況下還能怎么用呢?我們還可以想到三目運(yùn)算符。其實(shí)三目運(yùn)算符與if…else…思想大同小異,我們直接看代碼。

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、邏輯與操作符 &&

難度加大,在不用循環(huán)和if…else…和三目運(yùn)算符的情況下還能怎么用呢?好像不容易想出來其他方法了。其實(shí)當(dāng)我們熟知邏輯與操作符(&&)的一個特性時,也就很用以做出來。當(dāng)提到邏輯與操作符時,可能一時間想不到該怎么用。這時我們想想邏輯與操作符的性質(zhì)。當(dāng)兩個條件同時為真時才為真,當(dāng)?shù)谝粋€條件為假時,就不執(zhí)行第二個條件了。這就是我們要抓住的點(diǎn),來作為遞歸停止的條件。我們直接看代碼。

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;
}

其實(shí)這種解法就滿足本題目的要求了。

三、公式實(shí)現(xiàn)

公式實(shí)現(xiàn)的方法有很多,用乘除法、循環(huán)都很容易實(shí)現(xiàn)。但是題目中還要求了不能夠用乘除法,那怎么用公式實(shí)現(xiàn)呢?在這里用了一個很巧妙的方法,就是定義一個二維數(shù)組,數(shù)組存儲的數(shù)據(jù)類型大小為一個字節(jié),通過計(jì)算數(shù)組的大小,最后用右移操作符(>>)相當(dāng)于除于2來實(shí)現(xiàn)。我們結(jié)合代碼一起理解一下。

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++調(diào)用構(gòu)造函數(shù)累加法

我們都知道C++在類和對象中,實(shí)例化對象都會調(diào)用構(gòu)造函數(shù)。我們通過創(chuàng)建n個對象,同時設(shè)置成員變量為靜態(tài)的,調(diào)用構(gòu)造函數(shù)的累加法來實(shí)現(xiàn)。文字可能會有點(diǎn)不易理解,我們直接看代碼。

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();
    }
};

這種方法也是滿足題目的要求的。

我個人感覺這道題目挺有趣的,就整理出來跟大家分享一下。當(dāng)然,可能還有其它的解法,歡迎大家討論。

希望本篇文章對你有所幫助,感謝觀看ovo!

到此這篇關(guān)于C++另辟蹊徑計(jì)算1到n的和的文章就介紹到這了,更多相關(guān)C++計(jì)算1到n的和內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 深入了解C++封閉類的定義與使用

    深入了解C++封閉類的定義與使用

    一個類的成員變量如果是另一個類的對象,就稱之為“成員對象”。包含成員對象的類叫封閉類(enclosed?class)。本文主要和大家聊聊C++封閉類的使用,需要的可以參考一下
    2022-11-11
  • C語言詳解用char實(shí)現(xiàn)大小寫字母的轉(zhuǎn)換

    C語言詳解用char實(shí)現(xiàn)大小寫字母的轉(zhuǎn)換

    這篇文章主要給大家介紹了關(guān)于C語言實(shí)現(xiàn)大小寫字母轉(zhuǎn)換的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • C++設(shè)計(jì)模式之中介者模式

    C++設(shè)計(jì)模式之中介者模式

    這篇文章主要介紹了C++設(shè)計(jì)模式之中介者模式,本文講解了什么是中介者模式、中介者模式的使用場合、中介者模式的優(yōu)缺點(diǎn)等內(nèi)容,需要的朋友可以參考下
    2014-10-10
  • c語言stack(棧)和heap(堆)的使用詳解

    c語言stack(棧)和heap(堆)的使用詳解

    這篇文章主要介紹了c語言stack(棧)和heap(堆)的使用詳解,需要的朋友可以參考下
    2014-04-04
  • C++報錯:Segmentation Fault的解決方案

    C++報錯:Segmentation Fault的解決方案

    段錯誤(Segmentation Fault)是 C++ 編程中常見且令人頭疼的錯誤之一,段錯誤通常發(fā)生在程序試圖訪問未被允許的內(nèi)存區(qū)域時,導(dǎo)致程序崩潰,本文將深入探討段錯誤的產(chǎn)生原因、檢測方法及其預(yù)防和解決方案,需要的朋友可以參考下
    2024-07-07
  • C語言使用openSSL庫AES模塊實(shí)現(xiàn)加密功能詳解

    C語言使用openSSL庫AES模塊實(shí)現(xiàn)加密功能詳解

    這篇文章主要介紹了C語言使用openSSL庫AES模塊實(shí)現(xiàn)加密功能,詳細(xì)分析了C語言加密的相關(guān)概念、原理及AES模塊加密具體實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2017-05-05
  • C++項(xiàng)目開發(fā)實(shí)現(xiàn)圖書管理系統(tǒng)

    C++項(xiàng)目開發(fā)實(shí)現(xiàn)圖書管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C++項(xiàng)目開發(fā)實(shí)現(xiàn)圖書管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • C語言簡單實(shí)現(xiàn)掃雷小游戲

    C語言簡單實(shí)現(xiàn)掃雷小游戲

    這篇文章主要為大家詳細(xì)介紹了C語言簡單實(shí)現(xiàn)掃雷小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • 詳解C++如何實(shí)現(xiàn)在Word文檔中創(chuàng)建列表

    詳解C++如何實(shí)現(xiàn)在Word文檔中創(chuàng)建列表

    這篇文章主要為大家詳細(xì)介紹了介紹如何使用C++在Word文檔中創(chuàng)建編號列表、項(xiàng)目符號列表和多級列表,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-05-05
  • C++實(shí)現(xiàn)小型復(fù)數(shù)計(jì)算器

    C++實(shí)現(xiàn)小型復(fù)數(shù)計(jì)算器

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)小型復(fù)數(shù)計(jì)算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06

最新評論