珠玑妙算(详解)

题目:

代码:

cpp 复制代码
#include <stdio.h>
int* masterMind(char* solution, char* guess, int* returnSize) {
	*returnSize = 2;
	static int answer[2] = { 0 };//static关键字能使masterMind函数结束时,answer数组不会销毁
	memset(answer, 0, sizeof(answer));//用memset函数将数组全部初始化为0
	int s_answer[26] = { 0 };//26个字符位 solution 四种颜色数量统计
	int g_answer[26] = { 0 };//26个字符位 guess 四种颜色数量统计
	for (int i = 0; i < 4; i++) {
		if (solution[i] == guess[i]) {
			answer[0] += 1;//位置和颜色完全一致则猜中数量+1
		}
		else {
			//统计同一位置不同颜色的两组颜色数量,伪猜中不需要对应位置相同,只需要有对应数量的颜色就行
			s_answer[solution[i] - 'A'] += 1; //统计solution对应颜色字符出现次数
			g_answer[guess[i] - 'A'] += 1;//统计guess对应颜色字符出现次数
		}
	}
	//在两个颜色数量统计数组中查看颜色数量,取相同位置较小的一方就是为猜中数量
	for (int i = 0; i < 26; i++) {
		answer[1] += s_answer[i] > g_answer[i] ? g_answer[i] : s_answer[i];
	}
	return answer;
}

int main()
{
	char solution[] = "BRBB";
	char guess[] = "RBGY";
	int returnSize = 0;
	int* answer = masterMind(solution, guess, &returnSize);
	for (int i = 0; i < returnSize; i++) {
		printf("%d ", answer[i]);
	}
	return 0;
}

讲解:

"猜中" 和**"伪猜中"**分别计数。

使用 if else 语句即可满足题目中 **"猜中"不能算入"伪猜中"**这一条件。

cpp 复制代码
for (int i = 0; i < 4; i++) {
		if (solution[i] == guess[i]) {
			answer[0] += 1;//位置和颜色完全一致则猜中数量+1
		}
		else {
			//统计同一位置不同颜色的两组颜色数量,伪猜中不需要对应位置相同,只需要有对应数量的颜色就行
			s_answer[solution[i] - 'A'] += 1; //统计solution对应颜色字符出现次数
			g_answer[guess[i] - 'A'] += 1;//统计guess对应颜色字符出现次数
		}
	}

二者的计数条件有区别,"猜中" 是同一位置相等才加1,**"伪猜中"**是不同的位置但是猜到了就加1。

上述代码中同时遍历solution和guess数组,solution[i] == guess[i] 表示同一位置相等时,则只执行answer[0] += 1; 语句,不相等则只执行 s_answer[solution[i] - 'A'] += 1; g_answer[guess[i] - 'A'] += 1; 这样就将**"猜中"** 和**"伪猜中"**的计数方式就区分开了。
"伪猜中" 计数稍微复杂一点,相同的字母只能计数一次

例如:

solution ="BRBB"

guess ="RBGY"

这时的**"伪猜中"**数只能是2,因为字母B只能计数一次。

cpp 复制代码
//在两个颜色数量统计数组中查看颜色数量,取相同位置较小的一方就是为猜中数量
	for (int i = 0; i < 26; i++) {
		answer[1] += s_answer[i] > g_answer[i] ? g_answer[i] : s_answer[i];
	}

上述代码就可以完成对于重复的字母只计数一次的功能。无论是s_answer[i]大还是g_answer[i]大都取最小的一方。

当solution ="BRBB" ,guess ="RBGY"时,对于字母B,在 s_answer[26]中下标为1的数为3,在g_answer[26]中下标为1的数为1,则取较小的一方 g_answer[1]。


相关推荐
tt5555555555558 分钟前
C/C++嵌入式笔试核心考点精解
c语言·开发语言·c++
xiao助阵8 分钟前
python实现梅尔频率倒谱系数(MFCC) 除了傅里叶变换和离散余弦变换
开发语言·python
科大饭桶38 分钟前
C++入门自学Day14-- Stack和Queue的自实现(适配器)
c语言·开发语言·数据结构·c++·容器
tt5555555555551 小时前
字符串与算法题详解:最长回文子串、IP 地址转换、字符串排序、蛇形矩阵与字符串加密
c++·算法·矩阵
扛麻袋的少年2 小时前
7.Kotlin的日期类
开发语言·微信·kotlin
元亓亓亓2 小时前
LeetCode热题100--101. 对称二叉树--简单
算法·leetcode·职场和发展
躲在云朵里`2 小时前
深入理解数据结构:从数组、链表到B树家族
数据结构·b树
钢铁男儿2 小时前
Python 正则表达式实战:解析系统登录与进程信息
开发语言·python·正则表达式
不会学习?2 小时前
算法03 归并分治
算法
野生技术架构师2 小时前
2025年中高级后端开发Java岗八股文最新开源
java·开发语言