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

C語言通過深度優(yōu)先搜索來解電梯問題和N皇后問題的示例

 更新時間:2016年06月03日 14:49:46   作者:oopos  
深度優(yōu)先搜索即是對一個新發(fā)現(xiàn)的節(jié)點上如果還關(guān)聯(lián)未探測到的邊,就沿此邊探測下去,直到發(fā)現(xiàn)從原點可達(dá)的所有點為止,這里我們就來展示C語言通過深度優(yōu)先搜索來解電梯問題和N皇后問題的示例

N皇后問題
問題描述:
在n×n格的棋盤上放置彼此不受攻擊的n個皇后。按照國際象棋的規(guī)則,皇后可以攻擊與之處在同一行或同一列或同一斜線上的棋子。n后問題等價于再n×n的棋盤上放置n個皇后,任何2個皇后不妨在同一行或同一列或同一斜線上。
需求輸入:
給定棋盤的大小n (n ≤ 13)
需求輸出:
輸出有多少種放置方法。

#include <stdio.h>
#include <math.h>

#define MAX 101

int total = 0;
char m[MAX][MAX];
 
int is_ok(int s,int i,int *a)
{
  int j ;
  for(j=1 ; j< s ; j++)
  if( (abs(i-a[j]) == abs(s-j)) || (i == a[j])) /*按行填入,所以只要檢查列和斜列是否有皇后即可*/
    return 0 ;
  return 1 ;
}

void nfind(int s,int n,int *a)
{
  int i,p,q;

  if( s > n)
  {
    total ++ ;
    printf("========The num of %d is ========== ",total); 
    for(p=1 ; p<= n ; p++)
    {
      for(q=1; q<=n ; q++)
        printf("%c ",m[p][q]);
      printf(" ");
    }
    
  }
  else
  {
    for(i=1 ;i<= n; i++)
   
      if(is_ok(s,i,a))
      { 
         
        a[s]=i ;
        m[s][i]='O' ;
        nfind(s+1,n,a);
        m[s][i]='*' ;      
      }     
  }
}

int main(void)
{
  int n ,a[MAX]={0};
  scanf("%d",&n);
  memset(m,'*',sizeof(m));
  nfind(1,n,a);
  printf(" total=%d ",total);
  system("pause");
  return 0;
}

電梯問題
問題描述:
呵呵,有一天我做了一個夢,夢見了一種很奇怪的電梯。大樓的每一層樓都可以停電梯,而且第i層樓(1<=i<=N)上有一個數(shù)字Ki(0<=Ki<=N)。電梯只有四個按鈕:開,關(guān),上,下。上下的層數(shù)等于當(dāng)前樓層上的那個數(shù)字。當(dāng)然,如果不能滿足要求,相應(yīng)的按鈕就會失靈。例如:3 3 1 2 5代表了Ki(K1=3,K2=3,……),從一樓開始。在一樓,按“上”可以到4樓,按“下”是不起作用的,因為沒有-2樓。那么,從A樓到B樓至少要按幾次按鈕呢?
需求輸入:
輸入文件共有二行,第一行為三個用空格隔開的正整數(shù),表示N,A,B(1≤N≤200, 1≤A,B≤N),第二行為N個用空格隔開的正整數(shù),表示Ki。
需求輸出:
輸出文件僅一行,即最少按鍵次數(shù),若無法到達(dá),則輸出-1。
示例輸入:

5 1 5
3 3 1 2 5

示例輸出:

復(fù)制代碼 代碼如下:
3

實現(xiàn)代碼:

#include <stdio.h>
#define MAX 501

int a,b,n ;
int v[MAX],flag=0 ;

void trytofind(int x,int total)
{
   if(x-v[x] == b || x+v[x] == b)
   {
    
   if ( total < flag || flag == 0)
   flag = total ;
    
   }
   else
   {
    if(x+v[x] <= n)
    trytofind(x+v[x],total+1);
    if(x-v[x] >= 1)
    trytofind(x-v[x],total+1);
   }
   
}
int main(void)
{
  int i,j,k ;
  scanf("%d %d %d",&n,&a,&b);
  for(i=1 ; i<= n; i++)
  scanf("%d",&v[i]);
  
  trytofind(a,1) ;
  
  if(flag)
  printf("%d ",flag);
  else
  printf("-1 ");
  
  system("pause");
    
  return 0 ;

} 

相關(guān)文章

  • Qt實現(xiàn)拖拽功能圖文教程(支持拖放文件、拖放操作)

    Qt實現(xiàn)拖拽功能圖文教程(支持拖放文件、拖放操作)

    這篇文章主要給大家介紹了關(guān)于Qt實現(xiàn)拖拽功能(支持拖放文件、拖放操作)的相關(guān)資料,Qt是一款多平臺的C++應(yīng)用程序開發(fā)框架,它的獨特之處在于可以快速開發(fā)出拖放式的開發(fā)桌面程序,需要的朋友可以參考下
    2023-11-11
  • C++內(nèi)存泄漏及檢測工具詳解

    C++內(nèi)存泄漏及檢測工具詳解

    最簡單的方法當(dāng)然是借助于專業(yè)的檢測工具,比較有名如BoundsCheck,功能非常強(qiáng)大,相信做C++開發(fā)的人都離不開它。此外就是不使用任何工具,而是自己來實現(xiàn)對內(nèi)存泄露的監(jiān)控
    2013-10-10
  • C++結(jié)構(gòu)體與類指針知識點總結(jié)

    C++結(jié)構(gòu)體與類指針知識點總結(jié)

    在本篇文章里小編給大家整理了關(guān)于C++結(jié)構(gòu)體與類指針知識點以及相關(guān)內(nèi)容,有興趣的朋友們參考學(xué)習(xí)下。
    2019-09-09
  • C++ CryptoPP使用AES實現(xiàn)加解密詳解

    C++ CryptoPP使用AES實現(xiàn)加解密詳解

    Crypto++ (CryptoPP) 是一個用于密碼學(xué)和加密的 C++ 庫,提供了大量的密碼學(xué)算法和功能,這篇文章主要為大家介紹了C++ CryptoPP如何使用AES實現(xiàn)加解密,需要的可以參考下
    2023-11-11
  • C++使用初始化列表的方式來初始化字段的方法

    C++使用初始化列表的方式來初始化字段的方法

    今天小編就為大家分享一篇關(guān)于C++使用初始化列表的方式來初始化字段的方法,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2018-12-12
  • C++中std::find函數(shù)介紹和使用場景

    C++中std::find函數(shù)介紹和使用場景

    std::find函數(shù)是一個非常實用的通用查找算法,適用于各種場景,本文主要介紹了C++中std::find函數(shù)介紹和使用場景,具有一定的參考價值,感興趣的可以了解一下
    2024-02-02
  • C++編程中的命名空間基本知識講解

    C++編程中的命名空間基本知識講解

    這篇文章主要介紹了C++編程中的命名空間基本知識講解,包括對C++11中內(nèi)聯(lián)命名空間新特性的介紹,需要的朋友可以參考下
    2016-01-01
  • C++實現(xiàn)的泛型List類分享

    C++實現(xiàn)的泛型List類分享

    這篇文章主要介紹了C++實現(xiàn)的泛型List類分享,參考C#的List功能實現(xiàn),需要的朋友可以參考下
    2014-07-07
  • C&C++設(shè)計風(fēng)格選擇 命名規(guī)范

    C&C++設(shè)計風(fēng)格選擇 命名規(guī)范

    本文難免帶有主觀選擇傾向,但是會盡量保持客觀的態(tài)度歸納幾種主流的命名風(fēng)格,僅供參考
    2018-04-04
  • Cmake中強(qiáng)大的輸出函數(shù)message示例解析

    Cmake中強(qiáng)大的輸出函數(shù)message示例解析

    這篇文章主要介紹了Cmake中強(qiáng)大的輸出函數(shù)message解析,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-05-05

最新評論