




免费预览已结束,剩余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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 餐饮店服务员节假日安排及劳动合同
- 餐饮企业员工劳动保护与职业健康管理合同
- 厂房建设施工进度管理合同范本
- 2025年会策划方案模板(18篇)
- 军训开幕式学生演讲稿2025年(18篇)
- 人机交互测试的基本原则试题及答案
- 反担保人保证合同书
- 新闻学概论与实务试题集
- 化学工业分析与检测技术试题
- 培训服务合同书及课程安排细节说明
- 宠物血液库市场营销策划
- 采掘开工作面动态验收表
- 垃圾分类意识的培养与智能垃圾分类系统
- 人力资源管理与创新创业实践-青岛大学中国大学mooc课后章节答案期末考试题库2023年
- 电梯维保服务方案及措施方案
- 废品承包合同
- 酒水鉴赏与调酒技术智慧树知到答案章节测试2023年青岛恒星科技学院
- 读书笔记:《教育,向美而生》
- 排序算法及其算法分析课件
- 吸烟对人体危害和戒烟
- 子宫内膜增生课件
评论
0/150
提交评论