编程之美:中国象棋将帅问题

2024-02-01 05:08

本文主要是介绍编程之美:中国象棋将帅问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目大意:

设A表示“将”,B表示“帅”,AB均只能在各自的九宫格内移动,但是他们不能遥相对望,输出所有A、B的合法位置。要求只能使用一个变量。

分析:设九宫格如下:

1 2 3

4 5 6

7 8 9

假设我们已知了A位置i和B位置j,那么我们判断他们合法只需要判断i%3和j%3不等即可,那么我们的工作也就是怎么样只用一个变量将A、B位置都保存起来

1、可以用位的思想,用一个数中不同的位来表示不同的信息;

#include <stdio.h>
#define LENGTH 4
#define FULLMASK 255//表示11111111#define LMASK (FULLMASK << LENGTH)//表示11110000
#define RMASK (FULLMASK >> LENGTH)//表示00001111#define RSET(b,n) (b = (LMASK & b)^n)//将b的右边4bit设为n
#define LSET(b,n) (b = (RMASK & b)^(n << LENGTH))//将b的左边设为n#define RGET(b) (RMASK & b)//得到b右边的值
#define LGET(b) ((LMASK &b) >> LENGTH)//得到b左边的值#define GRIDW 3//表示将帅移动范围行宽度
int main(){unsigned char b;for(LSET(b,1); LGET(b) <= GRIDW*GRIDW; LSET(b,(LGET(b)+1)))for(RSET(b,1); RGET(b) <= GRIDW*GRIDW; RSET(b,(RGET(b)+1)))if(LGET(b)%GRIDW != RGET(b)%GRIDW)printf("A=%d,B=%d\n",LGET(b),RGET(b));return 0;
}


2、可以构造这样一个数i,用i/9+1表示A的位置(1~9),i%9+1表示B的位置(1~9),那么A共9个位置,B9个位置,所以共有81种方式,遍历这81种方式即可

#include <iostream>
#include <windows.h>
#include <stdlib.h>
#include <math.h>
using namespace std;int main(){BYTE i=81;while(i--){if(i/9%3==i%9%3)continue;printf("A=%d,B=%d\n",i/9+1,i%9+1);}return 1;
}

3、书中还提到一种算法,有个小错误已经改正,让我不是很苟同

#include <iostream>
#include <windows.h>
#include <stdlib.h>
#include <math.h>
using namespace std;struct{unsigned char a;unsigned char b;
} i;
int main(){for(i.a=1;i.a<=9;i.a++)for(i.b=1;i.b<=9;i.b++)if(i.a%3!=i.b%3)printf("A=%d,B=%d\n",i.a,i.b);return 1;
}

如果按照这种做法用结构体变量,那么题干所示只能使用一个变量就毫无意义了啊,因为无论我用多少个变量都可以,将之定义到一个结构体中,整体作为一个变量,有些投机取巧了

这篇关于编程之美:中国象棋将帅问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/666159

相关文章

好题——hdu2522(小数问题:求1/n的第一个循环节)

好喜欢这题,第一次做小数问题,一开始真心没思路,然后参考了网上的一些资料。 知识点***********************************无限不循环小数即无理数,不能写作两整数之比*****************************(一开始没想到,小学没学好) 此题1/n肯定是一个有限循环小数,了解这些后就能做此题了。 按照除法的机制,用一个函数表示出来就可以了,代码如下

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

购买磨轮平衡机时应该注意什么问题和技巧

在购买磨轮平衡机时,您应该注意以下几个关键点: 平衡精度 平衡精度是衡量平衡机性能的核心指标,直接影响到不平衡量的检测与校准的准确性,从而决定磨轮的振动和噪声水平。高精度的平衡机能显著减少振动和噪声,提高磨削加工的精度。 转速范围 宽广的转速范围意味着平衡机能够处理更多种类的磨轮,适应不同的工作条件和规格要求。 振动监测能力 振动监测能力是评估平衡机性能的重要因素。通过传感器实时监

缓存雪崩问题

缓存雪崩是缓存中大量key失效后当高并发到来时导致大量请求到数据库,瞬间耗尽数据库资源,导致数据库无法使用。 解决方案: 1、使用锁进行控制 2、对同一类型信息的key设置不同的过期时间 3、缓存预热 1. 什么是缓存雪崩 缓存雪崩是指在短时间内,大量缓存数据同时失效,导致所有请求直接涌向数据库,瞬间增加数据库的负载压力,可能导致数据库性能下降甚至崩溃。这种情况往往发生在缓存中大量 k

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

【编程底层思考】垃圾收集机制,GC算法,垃圾收集器类型概述

Java的垃圾收集(Garbage Collection,GC)机制是Java语言的一大特色,它负责自动管理内存的回收,释放不再使用的对象所占用的内存。以下是对Java垃圾收集机制的详细介绍: 一、垃圾收集机制概述: 对象存活判断:垃圾收集器定期检查堆内存中的对象,判断哪些对象是“垃圾”,即不再被任何引用链直接或间接引用的对象。内存回收:将判断为垃圾的对象占用的内存进行回收,以便重新使用。

Go Playground 在线编程环境

For all examples in this and the next chapter, we will use Go Playground. Go Playground represents a web service that can run programs written in Go. It can be opened in a web browser using the follow

【VUE】跨域问题的概念,以及解决方法。

目录 1.跨域概念 2.解决方法 2.1 配置网络请求代理 2.2 使用@CrossOrigin 注解 2.3 通过配置文件实现跨域 2.4 添加 CorsWebFilter 来解决跨域问题 1.跨域概念 跨域问题是由于浏览器实施了同源策略,该策略要求请求的域名、协议和端口必须与提供资源的服务相同。如果不相同,则需要服务器显式地允许这种跨域请求。一般在springbo