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

网站竞价推广都有哪些重庆网站建设重庆

网站竞价推广都有哪些,重庆网站建设重庆,网站建设彩铃,节庆时候的网站是怎么做的2023华为OD统一考试(AB卷)题库清单-带答案(持续更新)or2023年华为OD真题机考题库大全-带答案(持续更新) 项目描述: 张兵和王武是五子棋迷,工作之余经常切磋棋艺。这不,这…

2023华为OD统一考试(A+B卷)题库清单-带答案(持续更新)or2023年华为OD真题机考题库大全-带答案(持续更新)

项目描述:

张兵和王武是五子棋迷,工作之余经常切磋棋艺。这不,这会儿又下起来了。走了一会儿,轮张兵了,对着一条线思考起来了,这条线上的棋子分布如下

用数组表示: -1 0 1 1 1 0 1 01 1

棋子分布说明:

1.-1代表白子,0代表空位,1 代表黑子

2.数组长度L,满足 1 < L < 40,且L为奇数

你得帮他写一个程序,算出最有利的出子位置。最有利定义

1.找到一个空位(0),用棋子(1/-1)填充该位置,可以使得当前子的最大连续长度变大

2.如果存在多个位置,返回最靠近中间的较小的那个坐标;

3.如果不存在可行位置,直接返回-1:

4.连续长度不能超过5个(五字棋约束)

输入描述:

第一行: 当前出子颜色

第二行: 当前的棋局状态

输出描述

1个整数,表示出子位置的数组下标

示例1

输入:

1

-1 0 1 1 1 0 1 0 1 -1 1

输出:

5

说明:

当前为黑子 (1),放置在下标为5的位置,黑子的最大连续长度,可以由3到5

示例2

输入:

-1

-1 0 1 1 1 0 1 0 1 -1 1

输出:

1

说明:

当前为白子,唯一可以放置的位置下标为1,白子的最大长度,由1变为2

示例3

输入:

1

0 0 0 0 1 0 0 0 0 1 0

输出:

5

说明:

可行的位置很多,5最接近中间的位置坐标

public class GoBang {public static void main(String[] args) {Scanner sc = new Scanner(System.in);int chessPieces = Integer.parseInt(sc.nextLine());List<Integer> chessBoard = Arrays.stream(sc.nextLine().split(" ")).map(Integer::parseInt).collect(Collectors.toList());insertPosition(chessPieces,chessBoard);}public static void insertPosition(int chessPieces, List<Integer> chessBoard){//找到空位List<Integer> blank = new LinkedList<>();for (int i = 0; i < chessBoard.size();i++){if (chessBoard.get(i) == 0){blank.add(i);}}//向前、向后遍历连续值(最大连续(靠近中间坐标),长度不超过5)index(blank,chessBoard,chessPieces);}public static void index(List<Integer> blank, List<Integer> chessBoard ,int chessPieces){int middle = chessBoard.size()/2;ChessInfo chess1 = new ChessInfo(-1,-1);for (int i = 0; i < blank.size(); i++){//空白位置插入棋子的连续个数int letf = blank.get(i) - 1;int right = blank.get(i) + 1;int count = 1;Boolean end = true;while (end && letf >= 0 && right <= chessBoard.size() -1){//向前位置遍历if (chessBoard.get(letf) == chessPieces){letf--;count++;continue;}else if (chessBoard.get(right) == chessPieces){//向后遍历right++;count++;continue;}end = false;}//保留最合适的位置 比较连续值,比较离中间位置最近if (chess1.count < count && count <= 5){chess1.count = count;chess1.index = blank.get(i);} else if (chess1.count == count && count <= 5) {if (Math.abs(chess1.index - middle) > Math.abs(blank.get(i) - middle)){chess1.index = blank.get(i);}}}System.out.println(chess1.index);}@Datastatic class ChessInfo{int count;int index;public ChessInfo(int count, int index) {this.count = count;this.index = index;}}
}

http://www.yayakq.cn/news/777152/

相关文章:

  • 门户网站的建设费用沧州各种网站
  • 常德 网站建设四川成都新冠最新消息
  • 天津外贸网站建设公司制作收款网站
  • 娄底网站建设79ldwordpress 大数据量查询
  • 容桂佛山做app网站WordPress协会主题模板
  • 怎么自己做歌曲网站网页设计与制作代码软件
  • dede网站搬家更换空间重新安装建设招标项目常挂网站有哪些
  • 百度网盘网站开发文档模板江门网站制作公司
  • 北京市住房建设网站做网站需要服务器还是主机
  • 成都科技网站建设电wordpress加个微信登录
  • 网站规划分析的好处网站建设哪些资质
  • 企业级网站开发技术it外包服务提供商有哪些
  • 响应式网站的设计尺寸电商付费推广方式
  • 网站扫码登录怎么做贵州省冶金建设有限公司网站
  • 如何选技能网站建设wordpress缩进
  • 如何搜索网站的内容沈阳专业制作网站公司吗
  • 做的高大上的网站霞山网站建设公司
  • 网站能看出建设时间吗阿里云建站流程
  • 安全的赣州网站建设德骏网站建设
  • 无锡建设网站的公司简介wordpress comments.php
  • 一起做网站欧洲站优化师证书
  • 专业团队朋友圈文案山东seo百度推广
  • 手机微网站怎么制作wordpress 分类目录插件
  • delphi7 网站开发手机端的网站首页该怎么做
  • 沁水网站建设网站seo的重要性
  • 瓯北网站制作彩票网站怎么做系统
  • 房山建设网站2019建一个什么网站最好
  • 中国勘察设计行业信息化建设网站域名备案需要多少时间
  • 配送网站开发电商建网站运营
  • 立网站系北京集团公司注册流程