亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++遞歸算法實例代碼

 更新時間:2017年11月02日 09:02:15   作者:GMFTBY  
這篇文章主要介紹了C++遞歸算法實例代碼,還是比較不錯的,運用了遞歸算法解決相關(guān)問題,這里分享給大家,需要的朋友可以參考下。

遞歸算法,總結(jié)起來具有以下幾個特點:

    特點1  它有一個基本部分,即直接滿足條件,輸出
    特點2  它有一個遞歸部分,即 通過改變基數(shù)(即n),來逐步使得n滿足基本部分的條件,從而輸出
    特點3  在實現(xiàn)的過程中,它采用了分治法的思想:
       即將整體分割成部分,并總是從最小的部分(基本部分)開始入手(輸出),其背后的原理在于 當(dāng)整體遞歸到部分時,會保留整體的信息,部分滿足條件輸出的結(jié)果會被回溯給整體使用,從而使得整體輸出結(jié)果。
    特點4  每一步操作,整體都會將部分當(dāng)作其必要的一個步驟,從而實現(xiàn)整體步驟的完成

1.Question:

本題是用枚舉的思路來判斷一個規(guī)定的邏輯表達式是不是永真式

首先題目意思是最多不會有超過5個邏輯變量,有五種運算

Definitions of K, A, N, C, and E
     w  x   Kwx   Awx    Nw   Cwx   Ewx
  1  1   1   1    0   1   1
  1  0   0   1    0   0   0
  0  1   0   1    1   1   0
  0  0   0   0    1   1   1

其中

K &
A |
N !
C ->
E 同或

其中的C我們可以利用 !A | B 實現(xiàn)

E利用==實現(xiàn)

本題的主要難點并不在于實現(xiàn)我們的語句計算的方式

難點1:
遞歸求解表達式,在這里真的是有深刻的理解了遞歸的強大之處,我們本題的做法真的離不開遞歸,我們的做法是一個一個字符的開始枚舉的遞歸,每個字符分出10種情況,五種變量,五種運算符,這里我們添加一個指示器變量表示我們當(dāng)前的遞歸的位置和深度,我們不用設(shè)置我們的遞歸的終止條件,因為我們的表達式保證了一定是正確的,我們的計算結(jié)果一定是會有返回值的,我們的計算結(jié)果是一層一層的返回的

難點2:

位運算,我們本題如果不利用位運算的話,至少需要寫5層循環(huán)來模擬我們的變量的所有的情況,這樣太低效了,我們將我們的所有的變量封裝到一個一個字節(jié)的存儲器中,每次利用位運算提取相關(guān)的位置的數(shù)字就好了(雖然我們的表達式并不會運算所有的情況,但是至少不會錯)

Code:

#include"iostream"
#include"cstdio"
#include"cstdlib"
#include"cstring"
using namespace std;
int pos=0;
string data;
bool cal(int i)
{
	int t=pos++;
	switch(data[t])
	{
		case 'p':
			return (i >> 4)&1;
		case 'q':
			return (i >> 3)&1;
		case 'r':
		  return (i >> 2)&1;
		case 's':
		  return (i >> 1)&1;
		case 't':
		  return i&1;
		case 'K':
		  return cal(i) & cal(i);
		case 'A':
		  return cal(i) | cal(i);
		case 'N':
			return !cal(i);
		case 'C':
			return !cal(i) | cal(i);
		case 'E':
			return cal(i) == cal(i);
	}
}
bool isTautology()
{
	for(int i=0;i<=31;i++)
	{
		pos=0;
		if(cal(i)) continue;
		else return false;
	}
	return true;
}
int main()
{
	while(cin>>data&&data[0]!='0')
	{
		if(isTautology()) cout<<"tautology"<<endl;
		else cout<<"not"<<endl;
	}
	return 0;
}

總結(jié)

以上就是本文關(guān)于C++遞歸算法實例代碼的全部內(nèi)容,希望對大家有所幫助。歡迎參閱:C++中函數(shù)指針詳解及代碼分享C/C++ 編譯器優(yōu)化介紹等,有什么問題,可以隨時留言,歡迎大家交流討論。感謝朋友們對本站的支持!

相關(guān)文章

  • C 語言實現(xiàn)一個簡單的 web 服務(wù)器的原理解析

    C 語言實現(xiàn)一個簡單的 web 服務(wù)器的原理解析

    這篇文章主要介紹了C 語言實現(xiàn)一個簡單的 web 服務(wù)器的原理解析,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-11-11
  • MFC繪制不規(guī)則窗體的方法

    MFC繪制不規(guī)則窗體的方法

    這篇文章主要介紹了MFC繪制不規(guī)則窗體的方法,涉及MFC窗體操作的相關(guān)技巧,需要的朋友可以參考下
    2015-05-05
  • c++11新特性多線程操作實戰(zhàn)

    c++11新特性多線程操作實戰(zhàn)

    這篇文章主要介紹了c++11新特性多線程操作實戰(zhàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • 一篇文章了解c++中的new和delete

    一篇文章了解c++中的new和delete

    C語言提供了malloc和free兩個系統(tǒng)函數(shù),完成對堆內(nèi)存的申請和釋放,而C++則提供了兩個關(guān)鍵字new和delete,下面這篇文章主要給大家介紹了如何通過一篇文章了解c++中new和delete的相關(guān)資料,需要的朋友可以參考下
    2021-12-12
  • 詳解次小生成樹以及相關(guān)的C++求解方法

    詳解次小生成樹以及相關(guān)的C++求解方法

    這篇文章主要介紹了詳解次小生成樹以及相關(guān)的C++求解方法,文中的練習(xí)示例采用了kruskal算法通過C++進行求解,需要的朋友可以參考下
    2015-08-08
  • C++實現(xiàn)比特幣系統(tǒng)的源碼

    C++實現(xiàn)比特幣系統(tǒng)的源碼

    這篇文章主要介紹了C++實現(xiàn)比特幣系統(tǒng)的源碼,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-01-01
  • C++連連看判定圖形消除算法

    C++連連看判定圖形消除算法

    這篇文章主要為大家詳細介紹了C++連連看判定圖形消除算法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-12-12
  • C++中類的三種訪問權(quán)限解析:private、public與protect

    C++中類的三種訪問權(quán)限解析:private、public與protect

    這篇文章主要介紹了C++中類的三種訪問權(quán)限解析:private、public與protect,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • C語言中位域的使用詳解

    C語言中位域的使用詳解

    位域是C語言中的一種高級功能,允許程序員為結(jié)構(gòu)體的成員分配特定數(shù)量的位,本文主要為大家介紹了位域的使用以及優(yōu)缺點,希望對大家有所幫助
    2023-07-07
  • socket編程之bind()函數(shù)使用示例詳解

    socket編程之bind()函數(shù)使用示例詳解

    這篇文章主要為大家介紹了socket編程之bind()函數(shù)使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-10-10

最新評論