国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C++ > 正文

C++基本算法思想之窮舉法

2020-01-26 15:45:07
字體:
來源:轉載
供稿:網友

窮舉算法(Exhaustive Attack method)是最簡單的一種算法,其依賴于計算機的強大計算能力來窮盡每一種可能性,從而達到求解問題的目的。窮舉算法效率不高,但是適應于一些沒有規(guī)律可循的場合。

窮舉算法基本思想
窮舉算法的基本思想就是從所有可能的情況中搜索正確的答案,其執(zhí)行步驟如下:

(1)對于一種可能的情況,計算其結果。

(2)判斷結果是否符合要求,如果不滿足則執(zhí)行第(1)步來搜索下一個可能的情況;如果符合要求,則表示尋找到一個正確答案。

在使用窮舉法時,需要明確問題的答案的范圍,這樣才可以在指定的范圍內搜索答案。指定范圍之后,就可以使用循環(huán)語句和條件語句逐步驗證候選答案的正確性,從而得到需要的正確答案。

窮舉算法舉例
雞兔同籠問題最早記載于1500年前的《孫子兵法》,這是一個非常有名的問題。雞兔同籠的原文如下:

今有雞兔同籠,上有三十五頭,下有九十四足,問雞兔各幾只?

這個問題的大致意思是:在一個籠子里關著若干只雞和若干只兔,從上面數共有35個頭,從下面數共有94只腳。問籠中雞和兔的數量各是多少?

窮舉算法
這個問題需要計算雞的數量和兔的數量,我們通過分析可以知道雞的數量應該在1~35之間。這樣我們可以使用窮舉法來逐個判斷是否符合,從而搜索答案。

采用窮舉法求解雞兔同籠問題的程序示例代碼如下:

復制代碼 代碼如下:

/*
輸入參數head是籠中頭的總數,foot是籠中腳的總數,chicken是雞的總數,rabbit是兔的總數
返回結果為0,表示沒有搜索到符合條件的結果;
返回結果為1,表示搜索到了符合條件的結果
*/
int qiongju(int head,int foot,int *chicken,int * rabbit)
{
 int re,i,j;
 re=0;
 for(i=0;i<=head,i++)  //進行循環(huán)
 {
  j=head-i;
  if(i*2+j*4==foot) //進行判斷
  {
   re=1;  //找到答案
   *chicken=i;
   *rabbit=j;
  }
 }
 return re;
}

窮舉算法求解雞兔同籠問題
完整的瓊劇算法求解雞兔同籠問題的程序代碼如下:
復制代碼 代碼如下:

#include<iostream>
using namespace std;
/*
輸入參數head是籠中頭的總數,foot是籠中腳的總數,chicken是雞的總數,rabbit是兔的總數
返回結果為0,表示沒有搜索到符合條件的結果;
返回結果為1,表示搜索到了符合條件的結果
*/
int qiongju(int head,int foot,int *chicken,int * rabbit)
{
 int re,i,j;
 re=0;
 for(i=0;i<=head;i++)  //進行循環(huán)
 {
  j=head-i;
  if(i*2+j*4==foot)  //進行判斷
  {
   re=1;    //找到答案
   *chicken=i;
   *rabbit=j;
  }
 }
 return re;
}
int main()
{
 int chicken,rabbit,head,foot;
 int re;
 cout<<"窮舉法求解雞兔同籠問題:"<<endl;
 cout<<"請輸入頭數:";
 cin>>head;
 cout<<"請輸入腳數:";
 cin>>foot;
 re=qiongju(head,foot,&chicken,&rabbit);
 if(re==1)
 {
  cout<<"雞有"<<chicken<<"只,兔有"<<rabbit<<"只。"<<endl;
 }
 else
 {
  cout<<"無法求解!"<<endl;
 }
 return 0;
}

程序中,首先由用戶輸入頭的總數和腳的總數,然后調用窮舉法求解雞兔同籠問題的函數,最后輸出結果。

執(zhí)行該程序,按照題目的要求輸入數據,輸出結果。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 友谊县| 宜阳县| 肥城市| 阜阳市| 额济纳旗| 康马县| 浦城县| 哈密市| 前郭尔| 扬中市| 文水县| 肇州县| 柯坪县| 美姑县| 从江县| 河源市| 枣庄市| 岫岩| 大姚县| 莆田市| 若羌县| 晋江市| 阳新县| 康定县| 沧州市| 礼泉县| 蒲城县| 巫山县| 南郑县| 田阳县| 博白县| 江口县| 丰都县| 太和县| 榆林市| 沙洋县| 孝义市| 安徽省| 博兴县| 泰安市| 南雄市|