当前位置: 首页 > wzjs >正文

做php网站的环境友情链接免费发布平台

做php网站的环境,友情链接免费发布平台,zencart网站地图插件,wordpress 知呼目录 1 回溯法 1.1 N皇后问题 1.1.1 非递归求解N皇后问题 1.1.2 递归求解N皇后问题 1.2 真题 2 分治法 2.1 真题 3 动态规划法 3.1 0-1背包问题 3.2 真题 1 回溯法 1.1 N皇后问题 上图Q4与Q2在同一列且与Q1在同一斜线,先回溯到上一个皇后改变Q3皇后的位置…

目录

1 回溯法

1.1 N皇后问题

1.1.1 非递归求解N皇后问题

1.1.2 递归求解N皇后问题

1.2 真题

2 分治法

2.1 真题

3 动态规划法

3.1 0-1背包问题

3.2 真题


1 回溯法

1.1 N皇后问题

上图Q4与Q2在同一列且与Q1在同一斜线,先回溯到上一个皇后改变Q3皇后的位置,若不行,再向上回溯,直到回溯到第一个皇后位置可行,再向下回溯,直到每个皇后位置都可行。

在软考中,最终表示如下

1.1.1 非递归求解N皇后问题

#include <math.h>
#include <stdio.h>#define N 4
// #define N 10int q[N + 1]; // 存储皇后的列号int check(int j) { // 检查第 j 个皇后的位置是否合法int i;for (i = 1; i < j; i ++ ) {if (q[i] == q[j] || abs(i - j) == abs(q[i] - q[j])) { // 判断是否在同一列和同一斜线上return 0;}}return 1;
}void queen() { // 求解 N 皇后 方案int i;for (i = 1; i <= N; i ++ ) {q[i] = 0;}int answer = 0; // 方案数int j = 1; // 表示正在摆放第 j 个皇后while (j >= 1) {q[j] = q[j] + 1; // 让第 j 个皇后向后一列摆放while (q[j] <= N && !check(j)) { // 判断第 j 个皇后的位置是否合法q[j] = q[j] + 1; // 不合法就往后一个位置摆放}if (q[j] <= N) { // 表示第 j 个皇后的找到一个合法的摆放位置if (j == N) { // 找到了 N 皇后的一组解answer = answer + 1;printf("方案%d:", answer);for (i = 1; i <= N; i ++ ) {printf("%d ", q[i]);}printf("\n");} else {j = j + 1; // 继续摆放下一个皇后}} else { // 表示第 j 个皇后找不到一个合法的摆放位置q[j] = 0; // 还原第 j 个皇后的位置j = j - 1; // 回溯}}
}int main() {queen();return 0;
}

1.1.2 递归求解N皇后问题

#include <math.h>
#include <stdio.h>#define N 4
// #define N 10int answer = 0;
int q[N + 1]; // 存储皇后的列号int check(int j) { // 检查第 j 个皇后的位置是否合法int i;for (i = 1; i < j; i ++ ) {if (q[i] == q[j] || abs(i - j) == abs(q[i] - q[j])) { // 判断是否在同一列和同一斜线上return 0;}}return 1;
}void queen(int j) {int i;for (i = 1; i <= N; i ++ ) {q[j] = i;if (check(j)) { // 当摆放的皇后位置为合法时if (j == N) { // 找到了 N 皇后的一组解answer = answer + 1;printf("方案%d:", answer);for (i = 1; i <= N; i ++ ) {printf("%d ", q[i]);}printf("\n");} else {queen(j + 1); // 递归摆放下一个皇后的位置}}}
}int main() {queen(1);return 0;
}

1.2 真题

1.2015年上半年

2.2019年上半年

2 分治法

#include <stdio.h>
#include <sched.h>void Merge(int A[], int p, int q, int r) {int i, j, k;int L[50], R[50];int n1 = q - p + 1, n2 = r - q;for (i = 0; i < n1; i ++ ) {L[i] = A[p + i];}for (j = 0; j < n2; j ++ ) {R[j] = A[q + j + 1];}L[n1] = INT_MAX;R[n2] = INT_MAX;i = 0;j = 0;for (k = p; k < r + 1; k ++ ) {if (L[i] < R[j]) {A[k] = L[i];i ++ ;} else {A[k] = R[j];j ++ ;}}
}void MergeSort(int A[], int p, int r) {int q;if (p < r) {q = (p + r) / 2;MergeSort(A, p, q);MergeSort(A, q + 1, r);Merge(A, p, q, r);}
}int main() {int A[] = {4, 1, 3, 6, 8, 5, 2, 9};MergeSort(A, 0, 7);int i;for (i = 0; i < 8; i ++ ) {printf("%d ", A[i]);}return 0;
}

2.1 真题

1.2014年上半年

2.2017年上半年

3.2020年下半年

3 动态规划法

3.1 0-1背包问题

#include <stdio.h>#define N 4 // 物品数量
#define W 5 // 背包容量int max(int a, int b) {return a > b ? a : b;
}int main() {int v[] = {0, 2, 4, 5, 6}; // 物品价值数组int w[] = {0, 1, 2, 3, 4}; // 物品重量数组int f[N + 1][W + 1] = {}; // 子问题解数组int i, j;for (i = 1; i <= N; i ++ ) {for (j = 1; j <= W; j ++ ) {f[i][j] = f[i - 1][j]; // 默认不选第 i 个物品if (j >= w[i]) { // 选第 i 个物品的前提条件// 等于 不选第 i 个物品 和 选第 i 个物品 两者的较大值f[i][j] = max(f[i][j], f[i - 1][j - w[i]] + v[i]);}// 上方是写法 1/* ============================================================ */// 下方是写法 2 /*if (j >= w[i]) { // 选第 i 个物品的前提条件// 等于 不选第 i 个物品 和 选第 i 个物品 两者的较大值f[i][j] = max(f[i - 1][j], f[i - 1][j - w[i]] + v[i]);} else { // 不选第 i 个物品f[i][j] = f[i - 1][j]; // 等于 从前 i - 1 个物品中选,背包容量为 j 时的最大价值}*/}}printf("%d\n", f[N][W]);for (i = 0; i <= N; i ++ ) {for (j = 0; j <= W; j ++ ) {printf("%d ", f[i][j]);}printf("\n");}return 0;
}

3.2 真题

1.2019年下半年

2.2021年下半年

http://www.dtcms.com/wzjs/420512.html

相关文章:

  • 网站版面设计推广普通话手抄报文字
  • 帮别人做违法网站会判刑吗百度云网盘资源搜索
  • 一个人做网站原型信息检索关键词提取方法
  • 网站 缓存方式企业文化宣传策划方案
  • 小江高端网站建设域名怎么查
  • 合肥网站优化seo爱站站长工具
  • 山西网站建设公司国内免费ip地址
  • 群晖搭建wordpress不加端口潍坊seo招聘
  • 新郑网站建设公司2022年新闻摘抄十条简短
  • 代做计算机毕业设计网站福州网站制作推广
  • 四川省住建设厅网站云南seo
  • b2c网站推广山西seo
  • 网站建设调查报告范文在线查网站的ip地址
  • 广西专业建网站seo搜索优化公司报价
  • 上海雷蒙威手表网站免费发seo外链平台
  • 烟台北京网站建设长沙seo排名收费
  • 绛县苗木网网站是由谁建设的营销模式方案
  • 北方工业大学网站建设app广告联盟
  • 网站建设(中企动力)网销平台排名
  • 外包客服公司seo优化技巧有哪些
  • 防制网站怎么做凡科官网免费制作小程序
  • 建设银行网站上的的研究报告数据分析网
  • 苍南具城乡建设局网站seo整站优化
  • 网站商业授权含义网络推广方案范例
  • 毕业季网站如何做网页手机创建网站免费注册
  • 做网站找那些公司公众号开发
  • 怎么做导航网站互联网运营自学课程
  • 禅城网站建设费用网络推广渠道和方法
  • 如何上传网站源码青岛seo排名公司
  • 保亭县住房城市建设局网站如何建网站赚钱