首页 > 编程语言 >java解决就简单的亮灯问题

java解决就简单的亮灯问题

时间:2024-10-15 20:17:03浏览次数:14  
标签:java 简单 亮灯 房间 public boolean 编号 100 整除

100个房间 每个房间 1 盏灯    这些灯都是灭的
    // 1 2 3 4 5 6 7 8 9
    100个人coming
        第1个人    来到每个房间前
            如果房间编号能够整除1 (人的编号)
            拉一下灯
        第2个人    来到每个房间前
            如果房间编号能够整除2 (人的编号)
            拉一下灯
        第3个人    来到每个房间前
            如果房间编号能够整除3 (人的编号)
            拉一下灯
        。。。
        问:当 100 个人都拉完灯之后 哪些灯是亮的
        答:1 4 9 16 25 36 49 64 81 100

第一种:房间不动 人进行动态,但是只有小于等于房间编号的人才有机会被整除.

例如房间 32号  人33号,那么32号以后的人就无法被整除直接简化  j<=i

public class Test01{
	public static void main(String[] args){
		boolean flag;//灭的
		int i=1;
		for(i=1;i<=100;i++){//一百个房间
			flag=false;
			for(int j=1;j<=i;j++){//小于等于i的人才能有机会整除
				if(i%j==0){
					flag=!flag;
				}
			}
			if(flag){
				System.out.println(i);
			}
		}

	}
}

第二种:

public class Test02{
    public static void main(String[] args){
		// false
		boolean[] data = new boolean[100];
		// 人-外层
		for(int ren = 1; ren <= 100; ren++){
			// 人的编号是定的
			for(int room = 1; room <= 100; room++){
				// 人-1	房间-room=1
				// 如果 room 能够整除ren
				if(room%ren == 0){
					// 人进房间 拉data[room-1]灯
					data[room-1] = !data[room-1];
				}
			}
		}
		// 编号 = index+1
		for(int index = 0; index < data.length; index++){
			if(data[index]){// true
				System.out.println(index+1);
			}
		}
	}
}

 

 

标签:java,简单,亮灯,房间,public,boolean,编号,100,整除
From: https://blog.csdn.net/Miserables_/article/details/142928474

相关文章

  • 图文深入理解java对象从创建到回收都经历了什么
    1.前言:每个java对象都是有生命周期的,就像一个人的生命一样,从孕育到出生到成长变老最后由归于自然。笔者认为,Java对象的整个生命周期可以分为两个大的阶段:即创建阶段和运行阶段(包含对象的回收和消亡)。本篇将会图文深入介绍java对象的整个生命过程。一般人平时看到java其实......
  • Java中的变量和常量:数据的‘小盒子’和‘铁盒子’有啥不一样?
    什么是变量?在Java里,变量就是一个“可变的小盒子”,你可以随时改变它里面的数据。就像你有一个存钱罐,可以随时往里面放钱、取钱,今天装100块,明天变成200块,完全没问题。变量的定义:当你要定义一个变量时,你要告诉Java两个信息:这个“盒子”是用来装什么类型的数据(也就是数据类......
  • JAVA基础笔记1(变量与运算符+基本数据类型)
    目录一.开发工具1.快捷键常用二.HelloWorld案例:输出:心形三:变量与运算符3.1关键字3.2 标识符(identifier)3.3变量3.30变量的概念:3.31变量类型3.32引用数据类型:   类:class   数组:array   接口:interface   枚举:enum   注解:annotation   ......
  • 简单的漏洞技巧
    easybugtofind​ mostofthebeginerhunterneedstofindeasybugstostaymotivatedinthisfeild技巧1:破坏链接劫持进行冒充​​ 原文链接:[https://medium.com/@coffeeaddict_exe/500-in-5-minutes-45977e89a337]:​ 概要:​ 在网站下方找到了推特的链......
  • 前端原型链:探索 JavaScript 中的继承奥秘
    一、引言在前端开发领域,JavaScript是一门广泛应用的编程语言。而原型链作为JavaScript中一个重要的概念,对于理解JavaScript的面向对象特性和实现继承机制起着关键作用。它不仅影响着代码的组织和复用方式,还决定了对象之间的关系和属性访问规则。本文将深入探讨前端原型链......