CSP 202005-1 重复局面

news2025/3/13 22:00:26

题目背景

国际象棋在对局时,同一局面连续或间断出现3次或3次以上,可由任意一方提出和棋。

问题描述

国际象棋每一个局面可以用大小为 的字符数组来表示,其中每一位对应棋盘上的一个格子。六种棋子王、后、车、象、马、兵分别用字母 k、q、r、b、n、p 表示,其中大写字母对应白方、小写字母对应黑方。棋盘上无棋子处用字符 * 表示。两个字符数组的每一位均相同则说明对应同一局面。

现已按上述方式整理好了每步棋后的局面,试统计每个局面分别是第几次出现。

在这里插入图片描述

输入格式

从标准输入读入数据。

输入的第一行包含一个正整数 ,表示这盘棋总共有 步。

接下来 8*n行,依次输入第 1到第 8步棋后的局面。具体来说每行包含一个长度为 的字符串,每 8行字符串共 64个字符对应一个局面。

输出格式

输出到标准输出中。

输出共 n行,每行一个整数,表示该局面是第几次出现。

  • 样例输入
8
********
******pk
*****r*p
p*pQ****
********
**b*B*PP
****qP**
**R***K*
********
******pk
*****r*p
p*pQ****
*b******
****B*PP
****qP**
**R***K*
********
******pk
*****r*p
p*p*****
*b**Q***
****B*PP
****qP**
**R***K*
******k*
******p*
*****r*p
p*p*****
*b**Q***
****B*PP
****qP**
**R***K*
******k*
******p*
*****r*p
p*pQ****
*b******
****B*PP
****qP**
**R***K*
********
******pk
*****r*p
p*pQ****
*b******
****B*PP
****qP**
**R***K*
********
******pk
*****r*p
p*p*****
*b**Q***
****B*PP
****qP**
**R***K*
********
******pk
******rp
p*p*****
*b**Q***
****B*PP
****qP**
**R***K*
  • 样例输出
1
1
1
1
1
2
2
1

题解

package csp;

import java.util.*;

public class DuplicateSituation {
    static Map<String,Integer> map=new HashMap();
    static Set<String> set =new HashSet();
    static int N=100;
    static int n;
    public static void main(String[] args) {
        Scanner scanner=new Scanner(System.in);
         n=scanner.nextInt();
        for(int i=0;i<n;i++){
            StringBuilder sb=new StringBuilder();
            for(int j=1;j<=8;j++){
                String temp= scanner.next();
                sb.append(temp);
            }
            String s=sb.toString();
            if(set.contains(s)){
                int ans=map.get(s)+1;
                System.out.println(ans);
                map.put(s,ans);
            }else{
                map.put(s,1);
                System.out.println(1);
                set.add(s);
            }

        }
    }
}

思路

这道题数据量不大,就是简单的哈希表的运用,合理读取数据便能求解。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1007000.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Polarion导入需求(Word)

简介 将需求文档导入Polarion并实现自动创建工作项具有多个优势&#xff0c;这些优势有助于提高项目管理和协作的效率&#xff0c;以下是一些主要的优势点&#xff1a;减少手动工作&#xff1a; 自动创建工作项可以显著减少手动数据输入的工作量。不再需要手动逐一创建每个工作…

聚类-kmeans

聚类算法是无监督学习算法&#xff0c;指定将数据分成k个簇。然后通过每个点到各个簇的中心的欧氏距离来分类。 kmeans本身会陷入局部最小值的状况&#xff0c;二分kmeans可以解决这一点。 二分kmeans是遍历所有的簇&#xff0c;将其分成2个&#xff0c;比较哪一个分裂结果更…

2023年7月京东休闲食品行业品牌销售排行榜(京东大数据)

鲸参谋监测的京东平台7月份休闲食品市场销售数据已出炉&#xff01; 根据鲸参谋平台的数据显示&#xff0c;7月份休闲食品市场整体呈现下滑趋势。当月休闲食品在京东平台的销量为3400万&#xff0c;环比下降约26%&#xff0c;同比下降约26%&#xff1b;销售额将近11亿&#xf…

Equall Apple 的革命性变压器:一个宽幅前馈,实现前所未有的效率和精度

变压器架构已显示出显著的可扩展性&#xff0c;从而大大提高了精度。然而&#xff0c;这种进步是以极高的计算要求为代价的&#xff0c;这已成为实际应用中的重大障碍。 尽管研究人员一直在积极寻求解决方案来减小变压器组件的尺寸并修剪注意力头等元素&#xff0c;但另一个关…

自动化测试01

测试脚本编写参考 selenium IDE 插件&#xff0c;firefox浏览器搜索安装&#xff0c;&#xff08;无法安装&#xff09; katalon recorder 负责输出脚本&#xff0c;输出模式&#xff0c;python2unitest &#xff0c; 无法输出python3类型脚本&#xff0c;仅参考 开发者工具 …

Ubuntu安装Android Studio

一、Android Studio安装 官方教程&#xff1a;安装 Android Studio | Android Developers 1、下载&#xff1a;Download Android Studio & App Tools - Android Developers&#xff0c;选择linux版本 2、 提取/解压 将下载的安装包提取出来 3、 64位ubuntu系统&#…

三分钟创建扫码查分系统

学生考试的成绩是家长和学生关注的重要问题。传统的成绩查询方式往往需要将整个成绩表格发到群里&#xff0c;不仅操作繁琐&#xff0c;而且可能导致信息泄露。为了解决这个问题&#xff0c;易查分应运而生。易查分是一个可以将Excel表格转换为在线查询的工具&#xff0c;可以轻…

Python——操作MySQL数据库

&#x1f60a;Python——操作MySQL数据库 &#x1f680;前言&#x1f50d;数据库编程&#x1f36d;数据库编程基本介绍&#x1f36d;数据库编程接口&#x1f36d;什么情况下会使用Python操作MySQL数据库&#xff1f;&#x1f36d;Java和Python操作MySQL数据库有何不同&#xff…

基于Python开发的AI智能联系人管理程序(源码+可执行程序+程序配置说明书+程序使用说明书)

一、项目简介 本项目是一套基于Python开发的AI智能联系人管理程序&#xff0c;主要针对计算机相关专业的正在做毕设的学生与需要项目实战练习的Python学习者。 包含&#xff1a;项目源码、项目文档等&#xff0c;该项目附带全部源码可作为毕设使用。 项目都经过严格调试&#…

我的个人网站——宏夏Coding上线啦

网站地址&#xff1a;宏夏Coding Github地址&#xff1a;&#x1f525;&#x1f525;宏夏coding网站&#xff0c;致力于为编程学习者、互联网求职者提供最需要的内容&#xff01;网站内容包括求职秘籍&#xff0c;葵花宝典&#xff08;学习笔记&#xff09;&#xff0c;资源推…

核心实验18_ospf高级_ENSP

项目场景&#xff1a; 核心实验18_ospf高级_ENSP 多区域虚链路 实搭拓扑图&#xff1a; 具体操作&#xff1a; R1: [R1]ospf 1 router-id 1.1.1.1 [R1-ospf-1]area 0 [R1-ospf-1-area-0.0.0.0]net 1.1.1.0 0.0.0.255 [R1-ospf-1-area-0.0.0.0]net 10.1.12.0 0.0.0.255 [R1-os…

苹果电脑显示器校准推荐 BetterDisplay Pro for Mac

BetterDisplay Pro是一款Mac平台上的显示器校准软件&#xff0c;可以帮助用户调整显示器的颜色和亮度&#xff0c;以获得更加真实、清晰和舒适的视觉体验。 以下是BetterDisplay Pro的主要特点&#xff1a; - 显示器校准&#xff1a;可以根据不同的需求和环境条件调整显示器的颜…

车载多通道语音识别挑战赛(ICMC-ASR)丨ICASSP2024

由希尔贝壳、理想汽车、西工大音频语音与语言处理研究组、新加坡南洋理工大学、天津大学、WeNet开源社区、微软、中国信通院等单位发起的“车载多通道语音识别挑战赛”&#xff08;ICMC-ASR&#xff09;将作为IEEE声学、语音与信号处理国际会议&#xff08;ICASSP2024&#xff…

随机数问题

你知道 C 中的 rand() 函数是怎么实现的吗&#xff1f;你知道怎么在一维 / 二维 / 三维空间中等可能地随机取点吗&#xff1f; 随机数是一系列看似无规律、无法预测的数字或值的序列&#xff0c;其产生过程具有一定程度的不确定性。在计算机中&#xff0c;真正的绝对随机数是很…

当你的公司突然开始大量的裁员,被留下的你,真的准备好面对以后了吗?

留下来的&#xff0c;也是迷茫的 最近公司突然开始大量裁员&#xff0c;裁了一多半&#xff0c;作为唯一留下的APP 端开发人员&#xff0c;也开始陷入了焦虑&#xff0c;开始了思考&#xff0c;未来究竟何去何从&#xff0c;是否再去转到原生&#xff0c;从事原生的开发工作&a…

元服务那些事儿 | 挥剑解决隐私声明,激发开发豪情

话说元服务初上的年间&#xff0c;鸿蒙江湖高手云起&#xff0c;都是一顿键盘手猛敲&#xff0c;元服务推陈出新&#xff0c;创意层出不穷&#xff0c;无不风生水起。 江湖规矩&#xff1a;每个元服务必须提供规范的隐私声明&#xff0c;否则提交元服务发布上架后&#xff0c;将…

AI 为我制作了 5 份简历,过程太美好了

现在&#xff0c;每个人都在使用人工智能 (AI) 来让自己的生活变得更轻松——从订购杂货、找到丢失的钥匙到撰写完美的简历。人工智能简历生成器是令人惊叹的工具&#xff0c;但选择合适的工具可能是一项挑战。 人工智能简历写作工具的市场正在迅速扩大&#xff0c;并且越来越…

【Linux环境】编译器 gcc/g++的使用

​&#x1f47b;内容专栏&#xff1a; Linux操作系统基础 &#x1f428;本文概括&#xff1a; 预处理、编译、汇编、链接、动静态库、gcc选项等。 &#x1f43c;本文作者&#xff1a; 阿四啊 &#x1f438;发布时间&#xff1a;2023.9.13 背景知识 预处理&#xff08;进行宏替换…

element-ui文件下载(单个)

1. 单个附件下载 <el-buttontype"text"size"small"click.native.prevent"download(scope.row)" >下载</el-button>export default {data() {return {downloadUrl: http://127.0.0.1:8881/XX/XX, // 下载接口}},methods: {download(…

骨传导耳机怎么听到声音?骨传导耳机是否会对听力造成损害?

其实骨传导耳机让我们听到的的传声原理很简单&#xff0c;而且骨传导现象很常见&#xff0c;简单的来说&#xff0c;就是像我们平时吃薯片或者挠头发&#xff0c;无论声音再小&#xff0c;自己也能听见&#xff0c;这就是骨传导的现象&#xff0c;也是为啥骨传导耳机不需要入耳…