全排列与八皇后问题.doc_第1页
全排列与八皇后问题.doc_第2页
全排列与八皇后问题.doc_第3页
全排列与八皇后问题.doc_第4页
全排列与八皇后问题.doc_第5页
免费预览已结束,剩余1页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

一、输入n个不同的数进行全排列。思路:用一个数组保存输入的值,采用递归的方法从第一个开始把每个元素的值与数组中的所有的值都交换进行排列,比如在输入 1、2、3 时交换的方式可以像下面一样11, 22 , 33 输出11 , 23 , 32 输出12 , 21 , 33 输出12 , 13, 3 1 输出1 3 , 22 , 31 输出1 3 , 21 , 32 输出我的代码:#include #include void set(int a,int s,int n);int main(void)int n;int *p;printf(要全排的数的个数为:);scanf(%d,&n);printf(请输入%d个不同的数进行全排列:,n);p=new int n;for(int i=0;in;i+)scanf(%d,&pi);printf(输入的%d个数为:,n);for(int j=0;jn;j+)printf(%d ,pj);putchar(n);printf(全排列为:n);set(p,0,n);return 0;void set(int p,int s,int n)int i,temp;if(s=n-1)for(i=0;in;i+)printf(%d ,pi);putchar(n);elsefor(i=s;in;i+)temp=ps;ps=pi;pi=temp;set(p,s+1,n);temp=ps;ps=pi;pi=temp;二、八皇后问题递归的方式逐步排列,当最后一个皇后满足条件时则输出我的代码:.h 头文件;#define OK 1#define ERROR 0#define INIT_STACK 30#define INCREMENT 10typedef int Status;typedef structint x;int y;PosType;typedef structPosType* base;PosType* top;int len;* Slink,Stack;Status InitStack(Slink& S);Status Push(Slink S,PosType e);Status Pop(Slink S,PosType& e);int StackLength(Slink S);Status pass(Slink S,PosType e);void try_put(int n,Slink S);void output(Slink S);.cpp源文件:#include 八皇后.h#include #include #include #includeint totle=0;Status InitStack(Slink& S)S=(Slink)malloc(sizeof(Stack);if(!S)exit(0);S-base=(PosType*)malloc(INIT_STACK*sizeof(PosType);if(!S-base)exit(0);S-top=S-base;S-len=INIT_STACK;/printf(构造空栈完成nn);return OK;Status Push(Slink S,PosType e)if(S-top-S-base=S-len)S-base=(PosType*)realloc(S-base,(S-len+INCREMENT)*sizeof(PosType);if(!S-base)exit(0);S-top=S-base+S-len;S-len+=INCREMENT;*S-top+=e;/printf(%d进栈完成n,e);return OK;Status Pop(Slink S,PosType& e)if(S-top=S-base)printf(栈已为空nn);return ERROR;e=*-S-top;/printf(%d出栈完成nn,e);return OK;int StackLength(Slink S)/printf(栈的长度为:%dnn,S-top-S-base);return (S-top-S-base);Status pass(Slink S,PosType e)PosType* p=S-base;while(p!=S-top)if(p-y=e.y|abs(p-x-e.x)=abs(p-y-e.y)return ERROR;p+;return OK;void output(Slink S)int i,j;PosType* p=S-base;SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE),FOREGROUND_INTENSITY | FOREGROUND_RED | FOREGROUND_BLUE);printf(n第%3d种情况:n,+totle);for(i=0;i8;i+)for(j=0;jx=i&p-y=j)SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE),FOREGROUND_INTENSITY | FOREGROUND_RED);printf();elseSetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE),FOREGROUND_INTENSITY | FOREGROUND_GREEN);printf();printf(n);p+;if(totle=30)exit(0);void try_put(int n,Slink S)int i;PosType e;i=0;while(

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论