JS基础 -- 嵌套for循环

// 通过程序, 在页面中输出如下的图形:
// 第一个图形:
// *
// **
// ***
// ****
// *****
//
// 第二个图形:
// *****
// *****
// *****
// *****
// *****

        /*
         * 向body中输出一个内容,需要使用document.write("")
         * 
         * 要实现第二个图形,其实也很简单,也是很笨拙的方法,
         * 那就是复制五个document.write(""),或者在一个document.write("*****")
         * 中复制五个‘*’,也能实现一行五个‘*’。五行‘*’上下排列的话,只需要在第五个
         * document.write("")中加上‘<br>’换行标签,或者在document.write("*****")内加上
         * ‘<br>’换行标签就行,如下列第一个写法、第二个写法:。但是,这样写有些弊端,那就是不够机动性,
         * 复制粘贴也比较麻烦,代码更没有灵活性。为了解决这几个弊端,这里会使用嵌套for循环。
         */
        //第一个写法,复制五个document.write(""),并在第五个document.write("")里面加上换行标签
        //          document.write("*");
        //          document.write("*");
        //          document.write("*");
        //          document.write("*");
        //          document.write("*<br />");
        //          document.write("*");
        //          document.write("*");
        //          document.write("*");
        //          document.write("*");
        //          document.write("*<br />");
        //          ...
        //第二个写法,复制一个document.write("*****<br />")并在第五个*后面加上换行标签
        //          document.write("*****<br />");
        //          document.write("*****<br />");
        //          document.write("*****<br />");
        /*
         *  什么是嵌套for循环?
         *  嵌套for循环是指一个for循环内再写一个for循环。
         *  接下来就是第三个写法,开始写嵌套for循环
         *  
         *  通过题看图形,来分析步骤
         *  第一个图形有点难,所以先看第二个图形。
         *  首先,第二个图形的排列是一行五个‘*’,一排也是五个‘*’组成的长方形图案。
         *  要想输出这些 ‘*’ 就需要创建很多个document.write("*")
         *  这样写太麻烦,所以在这里需要创建for循环,来帮助实现这个功能
         *  一行五个‘*’,就需要创建五次,那么一排也是同样的意思
         *  那么在实现的时候,我们需要再写一个for循环来创建一排
         *  接下来就是实现一点一点实现嵌套for循环,
         */
        //第一,先创建一个for循环体
        for(var i = 0; i < 5; i++) {
            /*
             * 在循环的内部再创建一个for循环,用来控制图形的宽度
             * 目前,外部的for循环执行1次,内部就会执行5次
             * 内层循环可以来决定图形的宽度,执行几次图形的宽度是多少
             */
            for(var j = 0; j < 5; j++) {
                document.write("*&nbsp;&nbsp;&nbsp;");
            }
            document.write("<br />");
        }
        //设置分割线
        document.write("<br />");
        document.write("===分割线===<br />");
        document.write("<br />");

        /*
         * 第二个图形做好了,接下来就是第一个图形
         * 先把上面两个for循环复制下来为了区分两个图形,上面会做一个分割线
         */
        //外层是控制图形的高度
        for(var i = 0; i < 5; i++) {
            /*
             * 在循环的内部再创建一个for循环,用来控制图形的宽度
             * 目前,外部的for循环执行1次,内部就会执行5次
             * 内层循环可以来决定图形的宽度,执行几次图形的宽度是多少
             * 
             * 在上面矩形图形的写法里,内层控制的是宽度,也就是‘*’的个数。它的个数都是 5 个。
             * 而这个图形要求的是第一行是一个‘*’,第二行是两个‘*’,以此类推直至第五行是五个‘*’,
             * 这样就形成了一个直角三角形。
             * 上面矩形图形内层for循环是 j<5,这样就形成了矩形图形
             * 那这里是直角三角形的话,应该怎么写哪?
             * 首先,来看第一行是一个‘*’,第二行是两个‘*’,以此类推直至第五行是五个‘*’,这是一个递增的,
             * 那来看看谁是第一个循环的,外层for循环是第一个循环的,循环一次内层for循环也会循环,从这里就
             * 可以看出这是我们需要的,当外层for循环一次,内层for循环就要循环一次,当外层for循环二次时,内层for循环二次,
             * 也就是内层for循环的 j < i+1 ,这样就可以实现第一个图形
             */
            for(var j = 0; j < i + 1; j++) {
                document.write("*&nbsp;&nbsp;&nbsp;");
            }
            document.write("<br />");
        }
        //设置分割线
        document.write("<br />");
        document.write("===分割线===<br />");
        document.write("<br />");
        //如果把三角形倒过来实现的话,那怎么实现哪?
        //第三个图形
        //          *****
        //          ****
        //          ***
        //          **
        //          *
        for(var i = 0; i < 5; i++) {
            /*
             * 在循环的内部再创建一个for循环,用来控制图形的宽度
             * 目前,外部的for循环执行1次,内部就会执行5次
             * 内层循环可以来决定图形的宽度,执行几次图形的宽度是多少
             * 
             * 其实,很简单,那就是内层for循环  j < 5-i ,第一行是五个‘*’,第二行是四个‘*’,以此类推到第五行是一个‘*’
             * 只需要在外层循环一次,内层for循环就从 五个‘*’开始减去,当外层for循环条件变量 i 的值是 4 时,内层for循环就需要j < 5-4
             * 这个 4 也就是 i 的值
             */
            for(var j = 0; j < 5-i; j++) {
                document.write("*&nbsp;&nbsp;&nbsp;");
            }
            document.write("<br />");
        }
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,732评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,496评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,264评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,807评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,806评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,675评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,029评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,683评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,704评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,666评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,773评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,413评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,016评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,204评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,083评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,503评论 2 343

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,596评论 18 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,448评论 25 707
  • 隔了两年没有回老家过年,今年重新感受了家乡浓郁的年味、见到许多亲人熟悉的面孔,吃团圆饭、放鞭炮、上坟烧香、走亲戚...
    amao327阅读 188评论 3 0
  • 紧张和放松是一对反义词。因为知道自己的心理素质不好,这次学习科目二,我从一开始跑全程就告诉自己,把每一次练习都当成...
    云中看花阅读 132评论 2 2
  • 极简主义叙述与“毛细血管”式描写。 上阵“父子兵”
    含辛鱼阅读 260评论 0 0