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

C++遞歸算法實(shí)例代碼

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

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

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

1.Question:

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

首先題目意思是最多不會(huì)有超過5個(gè)邏輯變量,有五種運(yùn)算

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 實(shí)現(xiàn)

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

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

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

難點(diǎn)2:

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

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++遞歸算法實(shí)例代碼的全部?jī)?nèi)容,希望對(duì)大家有所幫助。歡迎參閱:C++中函數(shù)指針詳解及代碼分享、C/C++ 編譯器優(yōu)化介紹等,有什么問題,可以隨時(shí)留言,歡迎大家交流討論。感謝朋友們對(duì)本站的支持!

相關(guān)文章

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

    C語言中位域的使用詳解

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

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

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

最新評(píng)論