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

1116. 打印零与奇偶数

1116. 打印零与奇偶数

题目描述

假设有这么一个类:

class ZeroEvenOdd {
  public ZeroEvenOdd(int n) { ... }      // 构造函数public void zero(printNumber) { ... }  // 仅打印出 0public void even(printNumber) { ... }  // 仅打印出 偶数public void odd(printNumber) { ... }   // 仅打印出 奇数
}

相同的一个 ZeroEvenOdd 类实例将会传递给三个不同的线程:

  1. 线程 A 将调用 zero(),它只输出 0 。
  2. 线程 B 将调用 even(),它只输出偶数。
  3. 线程 C 将调用 odd(),它只输出奇数。

每个线程都有一个 printNumber 方法来输出一个整数。请修改给出的代码以输出整数序列 010203040506... ,其中序列的长度必须为 2n

 

示例 1:

输入:n = 2
输出:"0102"
说明:三条线程异步执行,其中一个调用 zero(),另一个线程调用 even(),最后一个线程调用odd()。正确的输出为 "0102"。

示例 2:

输入:n = 5
输出:"0102030405"

解法

题目要求交替打印,先打印0,再打印偶数,最后打印奇数。一共打印2*n个数字。

Java

import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.ReentrantLock;class ZeroEvenOdd {private int n;private int state = 0; // 0: print zero, 1: print odd, 2: print evenprivate ReentrantLock lock = new ReentrantLock();private Condition zeroCondition = lock.newCondition();private Condition evenCondition = lock.newCondition();private Condition oddCondition = lock.newCondition();public ZeroEvenOdd(int n) {this.n = n;}// printNumber.accept(x) outputs "x", where x is an integer.public void zero(IntConsumer printNumber) throws InterruptedException {for (int i = 0; i < n; i++) {lock.lock();try {while (state != 0) {zeroCondition.await();}printNumber.accept(0);if ((i + 1) % 2 == 1) {state = 1; // next print oddoddCondition.signal();} else {state = 2; // next print evenevenCondition.signal();}} finally {lock.unlock();}}}public void even(IntConsumer printNumber) throws InterruptedException {for (int i = 2; i <= n; i += 2) {lock.lock();try {while (state != 2) {evenCondition.await();}printNumber.accept(i);state = 0; // next print zerozeroCondition.signal();} finally {lock.unlock();}}}public void odd(IntConsumer printNumber) throws InterruptedException {for (int i = 1; i <= n; i += 2) {lock.lock();try {while (state != 1) {oddCondition.await();}printNumber.accept(i);state = 0; // next print zerozeroCondition.signal();} finally {lock.unlock();}}}
}

Java

class ZeroEvenOdd {private int n;private int state = 0; // 0: print zero, 1: print odd, 2: print evenpublic ZeroEvenOdd(int n) {this.n = n;}// printNumber.accept(x) outputs "x", where x is an integer.public void zero(IntConsumer printNumber) throws InterruptedException {for (int i = 0; i < n; i++) {synchronized (this) {while (state != 0) {this.wait();}printNumber.accept(0);if ((i + 1) % 2 == 1) {state = 1; // next print odd} else {state = 2; // next print even}this.notifyAll();}}}public void even(IntConsumer printNumber) throws InterruptedException {for (int i = 2; i <= n; i += 2) {synchronized (this) {while (state != 2) {this.wait();}printNumber.accept(i);state = 0; // next print zerothis.notifyAll();}}}public void odd(IntConsumer printNumber) throws InterruptedException {for (int i = 1; i <= n; i += 2) {synchronized (this) {while (state != 1) {this.wait();}printNumber.accept(i);state = 0; // next print zerothis.notifyAll();}}}
}

...


http://www.jsqmd.com/news/24457/

相关文章:

  • 2025年10月降本增效咨询公司推荐榜:五强数据横评
  • 2025 年水处理聚丙烯酰胺,聚丙烯酰胺水处理剂,工业废水处理聚丙烯酰胺厂家最新推荐,产能、专利、环保三维数据透视!
  • 2025 年阴离子聚丙烯酰胺,阳离子聚丙烯酰胺,非离子聚丙烯酰胺厂家最新推荐,产能、专利、环保三维数据透视
  • 2025 年聚丙烯酰胺絮凝剂,PAM 聚丙烯酰胺,聚丙烯酰胺聚合氯化铝厂家最新推荐,产能、专利、环保三维数据透视
  • 吱吱企业即时通讯:赋能企业高效沟通与协作新生态
  • 企业性能测试内训首选方案|让团队快速掌握全链路性能分析与优化
  • 2025 年装配式建筑,装配式集成房屋,装配式轻钢房屋,装配式公厕厂家最新推荐,产能、专利、环保三维数据透视
  • MATLAB实现光学综合孔径望远系统仿真
  • 2025 年装配式营地,装配式营地建设,装配式民宿,装配式出口厂家最新推荐,产能、专利、环保三维数据透视
  • Windows Server 2022 OVF (2025 年 10 月更新) - VMware 虚拟机模板
  • Linux运行时常用命令
  • 2025年盘式干燥机厂家权威推荐榜单:回转滚筒干燥机/真空干燥机/沸腾干燥机源头厂家精选
  • Windows Server 2025 OVF (2025 年 10 月更新) - VMware 虚拟机模板
  • 同步盘哪个好用?坚果云、百度网盘等五大工具横向对比
  • Windows Server 2008 R2 OVF (2025 年 10 月更新) - VMware 虚拟机模板
  • Windows Server 2019 OVF (2025 年 10 月更新) - VMware 虚拟机模板
  • 2025年装饰防火板厂家权威推荐榜单:环保防火板/耐刮防火板/隧道专用防火板源头厂家精选
  • Windows Server 2016 OVF (2025 年 10 月更新) - VMware 虚拟机模板
  • 基于Matlab/Simulink的CS-DCSK混沌键控系统仿真
  • tfman.dll tfdtctt8.dll textviewer.dll texturiz.dll texture9.dll texture7.dll TextTwist.exe - 详解
  • ansible 时间同步 实例
  • 2025年高压耐火装饰板厂家权威推荐榜单:高压耐火隔断板/建筑耐火板/高压耐火吊顶板源头厂家精选
  • 2025年10月环保板材品牌推荐:热度榜对比评测
  • CF1798D Shocking Arrangement 题解
  • P11994 [JOIST 2025] 外郎糕 题解
  • 告别手动上传!10款自动同步本地文件夹的网盘深度评测
  • 腾讯CodeBuddy:AI IDE的革命性突破,开发者工作方式的彻底重塑
  • C++中STL容器应用
  • P7914 [CSP-S 2021] 括号序列
  • 破解跨地域研发协同难题:2025主流制品管理平台选型对比与关键指标解析