LeetCode 319. 灯泡开关

1、题目

319. 灯泡开关 - 力扣(LeetCode) https://leetcode-cn.com/problems/bulb-switcher/submissions/

2、题解

这道题第一个便是扎扎实实的暴力法,就按照这一步一步的步骤去执行即可。这里的时间复杂度是n^2。超过时间限制。
第二种解法就是找规律,其实对于找规律这种东西,我觉得我是最不擅长的,通常都是枚举之后去观察规律。这道题既然是要求最终还亮几盏灯,那么我们就对灯的状态进行判断即可。如果灯的状态不再变化,我们便记录下来他的最终状态。由此可得:

1号灯,最终亮;
2号灯,最终灭;
3,灭。
4,亮。
5到8,灭。
9,亮。
......

也就是说,n以内的完全平方数的个数就是亮灯的数量,即等于n^0.5,也就是Math.sprt(n)。如此即可。

3、代码

暴力法(超过时间限制)

class Solution {
        public int bulbSwitch(int n) {
            if(n<=0){
                return 0;
            }
            //数组用int类型,0是关闭,1是开启。n是轮数,也是灯数。
            int[] lampArray = new int[n];//初始化全是关闭
            //Round 1.开所有的灯
            for (int i = 0; i < n; i++) {
               lampArray[i]=1;
            }
            int result=n-1;//过了1轮
            if(result<=0){
                return 1;
            }
            //Round 2,每两个灯泡你关闭一次。
            int nowRound2=0;
            while (nowRound2<n){
                if(nowRound2%2!=0){//奇数
                    lampArray[nowRound2]=0;//关闭
                }
                nowRound2++;
            }
            result--;
            if(result<=0){
                return 1;
            }
            //Round 3,每3个灯泡你切换一次。3到n都是如此
            //从i开始,每i个切换一次

            int condition=3;//从3开始
            while (condition<=n){
                //执行内部的循环遍历
                int nowRoundi=0;//最终结果
                while (nowRoundi<n){
                    if((nowRoundi+1)%condition==0){//1/2/3
                        //切换
                        if(lampArray[nowRoundi]==1){
                            //开->关
                            lampArray[nowRoundi]=0;
                        }else{
                            //关-》开
                            lampArray[nowRoundi]=1;
                        }
                    }
                    nowRoundi++;
                }
                //外循环累加
                condition++;
            }
            //遍历去数一数灯有几个亮
            int num=0;
            for (int i = 0; i < n; i++) {
                if(lampArray[i]==1){
                    num++;
                }
            }
            return num;
        }
    }

规律法:

 class Solution {
        public int bulbSwitch(int n) {
            return (int)Math.sqrt(n);
        }
    }

4、执行结果

暴力法执行结果:


image.png

规律法:


image.png
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,142评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,298评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,068评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,081评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,099评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,071评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,990评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,832评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,274评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,488评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,649评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,378评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,979评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,625评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,643评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,545评论 2 352

推荐阅读更多精彩内容

  • 题目 319. 灯泡开关 题目描述 初始时有 n 个灯泡关闭。 第 1 轮,你打开所有的灯泡。 第 2 轮,每两个...
    phantom34阅读 556评论 0 0
  • 昨晚睡下时快12点了,今早起床晚了些,已经六点半。大宝还是在听见声音后起床。其实早就醒了,只是懒得睁开眼。 大宝的...
    明懿妈妈阅读 252评论 0 5
  • 最近的晨读都没有了【剽悍晨读】四个大字。 “我喜欢你,你能够和我在一起吗?我会对你好的。” “不好意思,你不是我喜...
    李爹阅读 244评论 6 13
  • 想要问你: 人间姹紫嫣红,你何故独独掩门暗自垂泪,亲情的怀抱正温暖向你敞开,你何故匆匆作别今日且不待明日...
    馬境悅阅读 427评论 0 2
  • 一直以来,我都特别相信“这是一个看脸的时代”,赞同到都要举起双手和双脚来支持,我始终认为,颜值高就可以秒杀一切。 ...
    十月怀念阅读 4,268评论 2 0