C语言通过深度优先搜索来解电梯问题和N皇后问题的示例_C 语言

N皇后问题
问题描述:
在n×n格的棋盘上放置彼此不受攻击的n个皇后。按照国际象棋的规则,皇后可以攻击与之处在同一行或同一列或同一斜线上的棋子。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)上有一个数字Ki(0<=Ki<=N)。电梯只有四个按钮:开,关,上,下。上下的层数等于当前楼层上的那个数字。当然,如果不能满足要求,相应的按钮就会失灵。例如:3 3 1 2 5代表了Ki(K1=3,K2=3,……),从一楼开始。在一楼,按“上”可以到4楼,按“下”是不起作用的,因为没有-2楼。那么,从A楼到B楼至少要按几次按钮呢?
需求输入:
输入文件共有二行,第一行为三个用空格隔开的正整数,表示N,A,B(1≤N≤200, 1≤A,B≤N),第二行为N个用空格隔开的正整数,表示Ki。
需求输出:
输出文件仅一行,即最少按键次数,若无法到达,则输出-1。
示例输入:

5 1 5
3 3 1 2 5

示例输出:

复制代码 代码如下:

3

实现代码:

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

}

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索c语言
, n皇后问题
, 电梯问题
深度优先搜索
八皇后 深度优先、深度优先搜索c语言、深度优先遍历c语言、优先清算权条款示例、c语言代码示例,以便于您获取更多的相关知识。

时间: 2024-07-29 12:15:21

C语言通过深度优先搜索来解电梯问题和N皇后问题的示例_C 语言的相关文章

详解C++的模板中typename关键字的用法_C 语言

typename的使用场合 用处1, 用在模板定义里, 标明其后的模板参数是类型参数.例如 template<typename T, typename Y> T foo(const T& t, const Y& y){//....}; templace<typename T> class CTest { private: T t; public: //... } 其实,这里最常用的是使用关键字class,而且二者功能完全相同,这里的class和定义类时的class完

C语言 循环详解及简单代码示例_C 语言

C 循环 有的时候,我们可能需要多次执行同一块代码.一般情况下,语句是按顺序执行的:函数中的第一个语句先执行,接着是第二个语句,依此类推. 编程语言提供了更为复杂执行路径的多种控制结构. 循环语句允许我们多次执行一个语句或语句组,下面是大多数编程语言中循环语句的流程图: 循环类型 C 语言提供了以下几种循环类型.点击链接查看每个类型的细节. 循环类型 描述 while 循环 当给定条件为真时,重复语句或语句组.它会在执行循环主体之前测试条件. for 循环 多次执行一个语句序列,简化管理循环变量

详解C语言中的内存四区模型及结构体对内存的使用_C 语言

内存四区 1.代码区代码区code,程序被操作系统加载到内存的时候,所有的可执行代码都加载到代码区,也叫代码段,这块内存是不可以在运行期间修改的.2.静态区所有的全局变量以及程序中的静态变量都存储到静态区.3.栈区栈stack是一种先进后出的内存结构,所有的自动变量,函数的形参都是由编译器自动放出栈中,当一个自动变量超出其作用域时,自动从栈中弹出.对于自动变量,什么时候入栈,什么时候出栈,是不需要程序控制的,由C语言编译器.实现栈不会很大,一般都是以K为单位的. 当栈空间以满,但还往栈内存压变量

VC实现五子棋游戏的一个算法示例_C 语言

本文讲述了VC实现五子棋游戏的一个算法示例,该算法采用极大极小剪枝博弈算法,感兴趣的读者可以对程序中不完善的部分进行修改与完善. 该设计主要包括:数据结构.估值函数.胜负判断.搜索算法 程序运行界面如下: 具体实现步骤如下: 1.数据结构 //记录每步棋,可以建立链表用来进行悔棋.后退(本程序没有实现) struct Step { int x,y; //棋子坐标 int ball; //表示下子方{BLACK,WHITE} }; //记录棋盘情况,用于搜索过程 class CBoardSitua

详解C++设计模式编程中建造者模式的实现_C 语言

建造者模式:将一个复杂对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示.这是建造者模式的标准表达,不过看着让人迷惑,什么叫构建和表示的分离?一个对象使用构造函数构造之后不就固定了,只有通过它方法来改变它的属性吗?而且还要同样的构建过程搞出不同的表示,怎么可能呢?多写几个构造函数? 其实多写几个构造函数,根据不同参数设置对象不同的属性,也可以达到这样的效果,只是这样就非常麻烦了,每次要增加一种表示就要添加一个构造函数,将来构造函数会多得连自己都不记得了,这违背了开放-封闭的原则. 要

详解C++编程中类模板的相关使用知识_C 语言

有时,有两个或多个类,其功能是相同的,仅仅是数据类型不同,如下面语句声明了一个类: class Compare_int { public : Compare(int a,int b) { x=a; y=b; } int max( ) { return (x>y)?x:y; } int min( ) { return (x<y)?x:y; } private : int x,y; }; 其作用是对两个整数作比较,可以通过调用成员函数max和min得到两个整数中的大者和小者. 如果想对两个浮点数(

详解C++中的this指针与常对象_C 语言

C++ this指针详解 this 是C++中的一个关键字,也是一个常量指针,指向当前对象(具体说是当前对象的首地址).通过 this,可以访问当前对象的成员变量和成员函数. 所谓当前对象,就是正在使用的对象,例如对于stu.say();,stu 就是当前对象,系统正在访问 stu 的成员函数 say(). 假设 this 指向 stu 对象,那么下面的语句中,this 就和 pStu 的值相同: Student stu; //通过Student类来创建对象 Student *pStu = &s

详解C++中的对象指针与对象数组_C 语言

C++对象指针 指向对象的指针 在建立对象时,编译系统会为每一个对象分配一定的存储空间,以存放其成员.对象空间的起始地址就是对象的指针.可以定义一个指针变量,用来存放对象的指针. 如果有一个类: class Time { public : int hour; int minute; int sec; void get_time( ); }; void Time::get_time( ) { cout<<hour<<":"<<minute<<

详解C++编程中对于函数的基本使用_C 语言

形式参数和实际参数 在调用函数时,大多数情况下,函数是带参数的.主调函数和被调用函数之间有数据传递关系.前面已提到:在定义函数时函数名后面括号中的变量名称为形式参数(formal parameter,简称形参),在主调函数中调用一个函数时,函数名后面括号中的参数(可以是一个表达式)称为实际参数(actual parameter,简称实参). [例]调用函数时的数据传递. #include <iostream> using namespace std; int max(int x,int y)