八皇后问题 2017 4 24

本文通过两种不同的C++实现方式探讨了经典的八皇后问题。一种是使用全局变量和递归函数,另一种是定义了一个Queen类并利用成员函数进行求解。这两种方法都采用了回溯算法来找出所有可能的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 1 #include<iostream>
 2 #include<string.h>
 3 #include<algorithm>
 4 using namespace std;
 5 int queen[10] = {0};
 6 bool place(int k){
 7  for(int i=0;i<k;i++){
 8   if(queen[k]==queen[i]||abs(k-i)==abs(queen[i]-queen[k])){
 9    return false;
10   }
11  }
12  return true;
13 }
14 int count1=0;
15 void  back(int t,int n){
16  if(t>=n) 
17      count1++;
18  else{
19        for(int i=0;i<n;i++){
20        queen[t] = i;
21        if(place(t)){
22          back(t+1,n);
23        }
24     }
25     }
26 }
27 int main(){
28  int n;
29  while(cin>>n){
30     count1=0;
31     back(0,n);
32     cout<<count1<<endl; 
33  }
34  return 0;
35 } 
36 /*
37 #include <iostream>
38 #include <algorithm>
39 #include <string.h>
40 using namespace std;
41 class Queen{         //创建一个Queen类
42 public:
43     int count;
44     Queen(int n){
45         N = n;
46         count = 0;
47         memset(queens_N, 0, sizeof(queens_N));
48     };
49     bool Place(int k);  
50     void Backtrack(int t);  //回溯求解
51 private:
52     int N;
53     int queens_N[9];
54 };
55 bool Queen::Place(int k){         //寻找第k列的位置,要是没有位置了返回false,要是有位置,返回true
56     for (int j = 0; j < k; j++) {  //检查放在k位置的皇后是否可行
57         if (queens_N[k] == queens_N[j] || abs(k-j) == abs(queens_N[j] - queens_N[k])) return false;
58     }
59     return true;
60 }
61 void Queen::Backtrack(int t){     //回溯方法求解
62     if (t >= N) {
63         count ++;
64     }
65     else{
66         for (int i = 0; i < N; i++) {
67             queens_N[t] = i;
68             if (Place(t)) {
69                 Backtrack(t+1);
70             }
71         }
72     }
73 }
74 int main(int argc, const char * argv[]) {
75     // insert code here...
76     int N;
77     while (cin >> N) {
78         Queen queen(N);     //创建N黄后这个类
79         queen.Backtrack(0);  //从第一个位置加上回溯
80         cout << queen.count << endl;
81     }
82     return 0;
83 }      */  
84  
85 
86 /*#include<iostream>
87 using namespace std;
88 int count=0;
89 void f(int t){
90    if(t>0) f(t-1);
91    else count++;
92 }
93 int main(){
94  f(3);
95  cout<<count<<endl;
96 } */

 

转载于:https://www.cnblogs.com/sysu-eeman-yang/p/6754837.html

内容概要:本文档为《400_IB Specification Vol 2-Release-2.0-Final-2025-07-31.pdf》,主要描述了InfiniBand架构2.0版本的物理层规范。文档详细规定了链路初始化、配置与训练流程,包括但不限于传输序列(TS1、TS2、TS3)、链路去偏斜、波特率、前向纠错(FEC)支持、链路速度协商及扩展速度选项等。此外,还介绍了链路状态机的不同状态(如禁用、轮询、配置等),以及各状态下应遵循的规则和命令。针对不同数据速率(从SDR到XDR)的链路格式化规则也有详细说明,确保数据包格式和控制符号在多条物理通道上的一致性和正确性。文档还涵盖了链路性能监控和错误检测机制。 适用人群:适用于从事网络硬件设计、开发及维护的技术人员,尤其是那些需要深入了解InfiniBand物理层细节的专业人士。 使用场景及目标:① 设计和实现支持多种数据速率和编码方式的InfiniBand设备;② 开发链路初始化和训练算法,确保链路两端设备能够正确配置并优化通信质量;③ 实现链路性能监控和错误检测,提高系统的可靠性和稳定性。 其他说明:本文档属于InfiniBand贸易协会所有,为专有信息,仅供内部参考和技术交流使用。文档内容详尽,对于理解和实施InfiniBand接口具有重要指导意义。读者应结合相关背景资料进行学习,以确保正确理解和应用规范中的各项技术要求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值