LeetCode-1117. H2O 生成(多线程)

2024-06-03 13:32

本文主要是介绍LeetCode-1117. H2O 生成(多线程),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

LeetCode 题目描述

现在有两种线程,氢 oxygen 和氧 hydrogen,你的目标是组织这两种线程来产生水分子。

存在一个屏障(barrier)使得每个线程必须等候直到一个完整水分子能够被产生出来。

氢和氧线程会被分别给予 releaseHydrogen 和 releaseOxygen 方法来允许它们突破屏障。

这些线程应该三三成组突破屏障并能立即组合产生一个水分子。

你必须保证产生一个水分子所需线程的结合必须发生在下一个水分子产生之前。

换句话说:

  • 如果一个氧线程到达屏障时没有氢线程到达,它必须等候直到两个氢线程到达。
  • 如果一个氢线程到达屏障时没有其它线程到达,它必须等候直到一个氧线程和另一个氢线程到达。

书写满足这些限制条件的氢、氧线程同步代码。

示例 1:

输入: "HOH"
输出: "HHO"
解释: "HOH" 和 "OHH" 依然都是有效解。

示例 2:

输入: "OOHHHH"
输出: "HHOHHO"
解释: "HOHHHO", "OHHHHO", "HHOHOH", "HOHHOH", "OHHHOH", "HHOOHH", "HOHOHH" 和 "OHHOHH" 依然都是有效解。

限制条件:

  • 输入字符串的总长将会是 3n, 1 ≤ n ≤ 50;
  • 输入字符串中的 “H” 总数将会是 2n;
  • 输入字符串中的 “O” 总数将会是 n。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/building-h2o
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

题解

整体思考思路为:

  • 2 个线程并发执行
  • 2 个线程可执行的数量不同(限制线程数量)
  • 2 个线程等待状态互相制约(当前执行的线程需要生成一个水分子后后放行下一组线程)

1.Semaphore + CyclicBarrier

思路:使用信号量控制 2 个线程的访问数量,使用 CyclicBarrier 控制三三成组的执行。

考虑:CyclicBarrier 比较重量级。

class H2O {// 信号量 保证 H2/0 线程执行等待状态,即每次只有 2 个 H 线程、1 个 O 线程可执行private final Semaphore h2 = new Semaphore(2, false);private final Semaphore o = new Semaphore(1, false);// 屏障 ,保证线程三三成组执行private final CyclicBarrier barrier = new CyclicBarrier(3);public H2O() {}public void hydrogen(Runnable releaseHydrogen) throws InterruptedException {h2.acquire();try {barrier.await();} catch (BrokenBarrierException e) {throw new InterruptedException(e.getMessage());}// releaseHydrogen.run() outputs "H". Do not change or remove this line.releaseHydrogen.run();h2.release();}public void oxygen(Runnable releaseOxygen) throws InterruptedException {o.acquire();try {barrier.await();} catch (BrokenBarrierException e) {throw new InterruptedException(e.getMessage());}// releaseOxygen.run() outputs "O". Do not change or remove this line.releaseOxygen.run();o.release();}
}

2. Semaphore + AtomicInteger

思路:使用信号量控制 2 个线程的访问数量,使用 AtomicInteger(CAS) 控制三三成组的执行。

class H2O {// 信号量 保证 H2/0 线程执行等待状态,即每次只有 2 个 H 线程、1 个 O 线程可执行private final Semaphore h2 = new Semaphore(2, false);private final Semaphore o = new Semaphore(1, false);// 屏障 ,保证线程三三成组执行private final AtomicInteger barrier = new AtomicInteger();public H2O() {}public void hydrogen(Runnable releaseHydrogen) throws InterruptedException {h2.acquire();// releaseHydrogen.run() outputs "H". Do not change or remove this line.releaseHydrogen.run();barrier.getAndIncrement();resetBarrier();}public void oxygen(Runnable releaseOxygen) throws InterruptedException {o.acquire();// releaseOxygen.run() outputs "O". Do not change or remove this line.releaseOxygen.run();barrier.getAndIncrement();resetBarrier();}private void resetBarrier() {if (barrier.compareAndSet(3, 0)) { h2.release(2);o.release();}}
}

参考

  • 我的提交记录

这篇关于LeetCode-1117. H2O 生成(多线程)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python实现自动化Word文档样式复制与内容生成

《Python实现自动化Word文档样式复制与内容生成》在办公自动化领域,高效处理Word文档的样式和内容复制是一个常见需求,本文将展示如何利用Python的python-docx库实现... 目录一、为什么需要自动化 Word 文档处理二、核心功能实现:样式与表格的深度复制1. 表格复制(含样式与内容)2

python如何生成指定文件大小

《python如何生成指定文件大小》:本文主要介绍python如何生成指定文件大小的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python生成指定文件大小方法一(速度最快)方法二(中等速度)方法三(生成可读文本文件–较慢)方法四(使用内存映射高效生成

Maven项目中集成数据库文档生成工具的操作步骤

《Maven项目中集成数据库文档生成工具的操作步骤》在Maven项目中,可以通过集成数据库文档生成工具来自动生成数据库文档,本文为大家整理了使用screw-maven-plugin(推荐)的完... 目录1. 添加插件配置到 pom.XML2. 配置数据库信息3. 执行生成命令4. 高级配置选项5. 注意事

python多线程并发测试过程

《python多线程并发测试过程》:本文主要介绍python多线程并发测试过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、并发与并行?二、同步与异步的概念?三、线程与进程的区别?需求1:多线程执行不同任务需求2:多线程执行相同任务总结一、并发与并行?1、

MybatisX快速生成增删改查的方法示例

《MybatisX快速生成增删改查的方法示例》MybatisX是基于IDEA的MyBatis/MyBatis-Plus开发插件,本文主要介绍了MybatisX快速生成增删改查的方法示例,文中通过示例代... 目录1 安装2 基本功能2.1 XML跳转2.2 代码生成2.2.1 生成.xml中的sql语句头2

Python多进程、多线程、协程典型示例解析(最新推荐)

《Python多进程、多线程、协程典型示例解析(最新推荐)》:本文主要介绍Python多进程、多线程、协程典型示例解析(最新推荐),本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 目录一、multiprocessing(多进程)1. 模块简介2. 案例详解:并行计算平方和3. 实现逻

使用Python自动化生成PPT并结合LLM生成内容的代码解析

《使用Python自动化生成PPT并结合LLM生成内容的代码解析》PowerPoint是常用的文档工具,但手动设计和排版耗时耗力,本文将展示如何通过Python自动化提取PPT样式并生成新PPT,同时... 目录核心代码解析1. 提取 PPT 样式到 jsON关键步骤:代码片段:2. 应用 JSON 样式到

SpringBoot实现二维码生成的详细步骤与完整代码

《SpringBoot实现二维码生成的详细步骤与完整代码》如今,二维码的应用场景非常广泛,从支付到信息分享,二维码都扮演着重要角色,SpringBoot是一个非常流行的Java基于Spring框架的微... 目录一、环境搭建二、创建 Spring Boot 项目三、引入二维码生成依赖四、编写二维码生成代码五

Android与iOS设备MAC地址生成原理及Java实现详解

《Android与iOS设备MAC地址生成原理及Java实现详解》在无线网络通信中,MAC(MediaAccessControl)地址是设备的唯一网络标识符,本文主要介绍了Android与iOS设备M... 目录引言1. MAC地址基础1.1 MAC地址的组成1.2 MAC地址的分类2. android与I

PyQt5+Python-docx实现一键生成测试报告

《PyQt5+Python-docx实现一键生成测试报告》作为一名测试工程师,你是否经历过手动填写测试报告的痛苦,本文将用Python的PyQt5和python-docx库,打造一款测试报告一键生成工... 目录引言工具功能亮点工具设计思路1. 界面设计:PyQt5实现数据输入2. 文档生成:python-