【linux rand 源码】【源码怎么转化tni】【access 源码单独运行】c队列源码_队列源代码

2025-01-24 14:36:00 来源:9120选股公式源码 分类:探索

1.c����Դ��

c队列源码_队列源代码

c����Դ��

       #include "stdafx.h"

       #include "stdio.h"

       #include "malloc.h"

       #define MAX 8

       static int Queen[8][8];

       static int a=1;

       typedef struct

       {

        int *elem;

        int top;

       }ColStack;//栈:存放每一行放置皇后的队代码列号

       void InitQueen()

       {

        int i,j;

        for(i = 0; i < 8; i++)

        {

        for(j = 0; j < 8; j++)

        {

        Queen[i][j] = 0;

        }

        }

       }

       int InitStack(ColStack &CS)//初始化栈

       {

        CS.elem = (int *)malloc(MAX*sizeof(int));

        if(!CS.elem) return 0;

        CS.top = -1;

        return 1;

       }

       int Push(ColStack &CS, int e)//进栈

       {

        if(CS.top >= 8) return 0;

        CS.top++;

        CS.elem[CS.top] = e;

        return 1;

       }

       int Pop(ColStack &CS, int &e)//退栈

       {

        if(CS.top == -1)return 0;

        e = CS.elem[CS.top];

        CS.top--;

        return 1;

       }

       int Back(ColStack &CS,int &e)//回溯

       {

        Pop(CS,e);

        Queen[CS.top+1][e] = 0;

        if(e == 7 && CS.top == -1)

        {

        return 0;

        }

        if(e == 7 && CS.top != -1)

        {

        Back(CS,e);

        }

        return 1;

       }

       int OK(int i, int j)//检查(i,j)上能否放棋子

       {

        int k, m;

        for(k = i; k >= 0; k--)//检查同列

        {

        if(Queen[k][j] == 1) return 0;

        }

        k = i; m = j;

        while(k >= 0 && m >= 0)

        {

        if(Queen[k][m] == 1) return 0;

        k--; m--;

        }

        k = i; m = j;

        while(k >= 0 && m < 8)

        {

        if(Queen[k][m] == 1) return 0;

        k--;m++;

        }

        return 1;

       }

       //进入本函数时,在8*8棋盘前i-1行已放置了互不攻

       // 击的列源列源linux rand 源码i-1个棋子。现从第 i 行起继续为后续棋子选择

       // 满足约束条件的码队源码怎么转化tni位置。当求得(i>8)的队代码access 源码单独运行一个合法布局

       // 时,输出之。列源列源ccx指标源码6

       int queen(int i,码队美聊源码6 ColStack &CS, int start)

       {

        int j, k,e;

        if(i>=8)

        {

        printf("第%d种情况:\n",a);

        for(j = 0; j < 8; j++)

        {

        for(k = 0; k < 8; k++)

        {

        if(Queen[j][k] == 0)

        {

        printf("# ");

        }

        else

        {

        printf("@ ");

        }

        }

        printf("\n");

        }

        a++;

        }else

        {

        for(j = start+1; j < 8; j++)

        {

        if(OK(i,j) == 1)

        {

        Queen[i][j]=1;

        Push(CS,j);

        queen(i+1,CS,-1);

        return 1;

        }

        }

        }

        if(j == 8)

        {

        if(Back(CS,e) == 1)

        {

        queen(CS.top+1,CS,e);

        }

        if(Back(CS,e) == 0)

        {

        return 1;

        }

        }

       }

       int main()

       {

        InitQueen();

        ColStack cs;

        InitStack(cs);

        queen(0,cs,-1);

        return 0;

       }

       这是一个八皇后问题,是队代码个典型的出队列、入队列问题

列源列源

更多资讯请点击:探索

热门资讯

溯源码类型_溯源码有几种

2025-01-24 14:18310人浏览

gpu分析源码_gpu分析工具

2025-01-24 13:031564人浏览

chrome源码 ui

2025-01-24 12:49870人浏览

中美经济工作组举行第一次会议

2025-01-24 12:382510人浏览

推荐资讯

去“滤镜”•换新灯•探市场

中国消费者报南宁讯记者顾艳伟)12月4日,广西壮族自治区柳城县市场监管局对东泉农贸市场及其周边商超进行检查,发现一家小型超市售卖肉类的摊点仍在使用“生鲜灯”。同日,鹿寨县市场监管局开展日常监督检查,发

linuxbond分析源码_linux源码分析工具

1.Linux绑定bond0实现网络高可用linuxbond02.bondlinuxmodebondlinux3.linux服务器"网卡"丢包问题分析Linux绑定bond0实现网络高可用linuxb

防追封源码_防追封软件

1.解封密钥是多少?解封密钥是多少? 一些网友的微信账号被封了,就到处寻找微信解封的方法,而一些帖子会提到微信解封器这一类软件,那么,微信解封器是真的吗?在今天的文章中,小编就挑选了6款微信解封器