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

柳州正规网站建设加盟西安seo排名公司

柳州正规网站建设加盟,西安seo排名公司,中国建设工程招投网站,杭州网站的建设珠玑妙算游戏,OJ练习 一、描述二、方法一三、方法二 一、描述 珠玑妙算游戏(the game of master mind)的玩法如下: 计算机有4个槽,每个槽放一个球,颜色可能是红色(R)、黄色&#xf…

珠玑妙算游戏,OJ练习

  • 一、描述
  • 二、方法一
  • 三、方法二

一、描述

珠玑妙算游戏(the game of master mind)的玩法如下:
计算机有4个槽,每个槽放一个球,颜色可能是红色(R)、黄色(Y)、绿色(G)或蓝色(B)。例如,计算机可能有RGGB 4种(槽1为红色,槽2、3为绿色,槽4为蓝色)。作为用户,你试图猜出颜色组合。打个比方,你可能会猜YRGB。要是猜对某个槽的颜色,则算一次“猜中”;要是只猜对颜色但槽位猜错了,则算一次“伪猜中”。注意,“猜中”不能算入“伪猜中”,本题OJ链接
给定一种颜色组合solution和一个猜测guess,编写一个方法,返回猜中和伪猜中的次数answer,其中answer[0]为猜中的次数,answer[1]为伪猜中的次数。
示例1:
输入:solution=“RGBY”,guess=“GGRR”
输出:[1,1]
解释:猜中1次,伪猜中1次
示例2:
输入:solution=“BRBB”,guess=“RBGY”
输出:[0,2]
解释:猜中0次,伪猜中2次
示例3:solution=“BRGG”,guess=“BBRR”
输出:[1,1]
解释:猜中1次,伪猜中1次
提示:
len(solution) = len(guess) = 4
solution和guess仅包含"R",“G”,“B”,"Y"这4种字符

二、方法一

1、先计算猜中次数,统计solution和guess中相同下标相等的元素,并将相等的元素都赋值为0,最后统计相等的次数就是猜中的次数
2、再计算伪猜中次数(注意:如果solution[i]==guessj,则是伪猜中,后面的对比这两个位置都不能再用了)依次用数组guess中的非0元素和solution中的每个非0元素对比,统计相等的次数,并将相等的元素赋值为0,并且重新用下一个guess中的元素和solution中的每个非0元素对比,最后统计相等的次数就是伪猜中次数
代码实现:

int* masterMind(char* solution, char* guess, int* returnSize)
{int* returnArr = (int*)calloc(2, sizeof(int));*returnSize = 2;int i = 0;for(i = 0; i < 4; i++) //计算猜中{if(solution[i] == guess[i]){returnArr[0]++;solution[i] = guess[i] = 0;}}int j = 0;for(i = 0; i < 4; i++) //计算伪猜中{if(guess[i] != 0){for(j = 0; j < 4; j++){if(solution[j] != 0 && solution[j] == guess[i]){returnArr[1]++;solution[j] = 0;break;}}}}return returnArr;
}

三、方法二

猜中次数:若位置相同且颜色字符也相同,则猜中次数计数器+1
伪猜中次数:颜色相同,但是在不同位置,这时候只需要除去猜中位置之外,统计两个数组中各个字符出现的数量,取较小的一方就是每种颜色伪猜中的数量了。

int* masterMind(char* solution, char* guess, int* returnSize)
{int* returnArr = (int*)calloc(2, sizeof(int)); //开辟返回数组int* flagSolution = (int*)calloc(26, sizeof(int)); //统计solution中颜色字符数量的数组,flagSolution['G'-'A']表示颜色G出现的次数int* flagGuess = (int*)calloc(26, sizeof(int)); //统计guess中颜色字符数量的数组,flagGuess['G'-'A']表示颜色G出现的次数*returnSize = 2;int i = 0;for(i = 0; i < 4; i++) //因为只有四个字符,所有循环4次{if(solution[i] == guess[i]) //猜中了,猜中次数增加{returnArr[0]++;}else{flagSolution[solution[i] - 'A'] += 1;flagGuess[guess[i] - 'A'] += 1;}}for(i = 0; i < 26; i++) //处理统计数量的数组,取对应颜色字符数量的较小值{returnArr[1] += flagSolution[i] < flagGuess[i] ? flagSolution[i] : flagGuess[i];}return returnArr;
}
http://www.yayakq.cn/news/434439/

相关文章:

  • 珠海多语种网站制作网站制作公司 顺的
  • 浙江网站建设营销网站开发包含上线吗
  • 大学网站建设与管理职责装饰公司网站规划方案
  • 珠宝网站源码专门做萝莉视频网站
  • 哪个网站做任务可以赚钱国内好的网站建设
  • 有谁知道知乎网站是谁做的建设工程信息网一体化平台
  • 网站服务器哪家好些建设部网站 标准定额司
  • 邯郸企业网站建设乐清比较好的设计公司
  • 重庆建筑证书查询网站教人做家务的网站
  • 表白网站在线制作app网址你懂我意思正能量免费
  • 备案 网站名称 重复建筑电工证查询网站
  • 平顶山公司做网站微信公众平台小程序在哪
  • 淮安集团网站建设好的模板网站
  • 巴零网站建设微信制作微网站开发
  • 怎么给网站绑定域名网站怎么加载图片做logo
  • wordpress函数调用库seo技术是什么意思
  • 企业网站源码 企业网站管理系统360如何做免费的网站
  • 品牌网站建设专业定制微信定制网站建设
  • 昆明网站建设SEO公司宁海县城镇建设局网站
  • 西安前端开发招聘重庆有哪些做优化的公司
  • 嵩县网站开发网站后台帐号
  • 网站设计公司有名乐云seo营口建网站
  • 北京网站公司哪家好陕西建设厅官网系统平台
  • 做个营销网站中国空间站图片
  • wordpress 执行了两次网站文字优化方案
  • 网站底部工信部链接怎么做物联网软件定制开发
  • php旅游网站开发小结一般自己怎么做网站
  • 网站 后台 回车不了旅游网站建设项目报告论文
  • 网页设计网站题目上海网站建设制作公
  • 钦州浦北网站建设河南那家公司做家具行业网站好