//一、 画一个直角三角形
    // 第几行   *号数
    // *        1        1  
    // **       2        2
    // ***      3        3
    // ****     4        4
    // *****    5        5
    // 规律:行数 = *号数
    function left(n){  //  right为函数名,n为形式参数,用于接收实体参数。
        for(var i = 1; i <= n; i++){    //  声明i为打印行数
            for(var j = 1; j <= i; j++){       //声明j为一行打印多少个*
                document.write("*");
            }
            document.write("<br>");     //每打印一行就执行一次换行
        }
    }
    left(5);      //要求函数打印10行*,实体参数!
    // 二、画一个直角三角形
    //     *    4    空格    1    *
    //    **    3    空格    2    *
    //   ***    2    空格    3    *
    //  ****    1    空格    4    *
    // *****    0    空格    5    *
    // 规律: 一行 : 空格 + *;
    //          空格 = 总行数 - 空格所在行数
    //          行数 = *号数
    function right(n){
        for(var i = 1; i <= n; i++){    //  声明i为打印行数
            for(var k = 1; k <= n - i; k++){ //声明k为打印空格
                document.write("&ensp;");
            }
            for(var j = 1; j <= i; j++){       //声明j为一行打印多少个*
                document.write("*");
            }
            document.write("<br>");     //每打印一行就执行一次换行
        }
    }
    right(5);
    // 三、画一个等腰三角形
    //                         行数
    //         锋             j= 1     空格 4       锋    1
    //       锋锋锋          j= 2      空格 3        锋    3
    //     锋锋锋锋锋         j= 3      空格 2       锋    5
    //   锋锋锋锋锋锋锋       j = 4     空格 1       锋    7
    // 锋锋锋锋锋锋锋锋锋       j = 5    空格 0       锋    9
    //                                 空格5-j      锋   2*j-1
    // 思路:我们输出的空格数只算文字左边的即可!按最大行数-锋字个数
    // 规律: 空格 = 最大行数 - 单个行数;  锋 = 2 * 单个行数 - 1;
    function all(n){
        for(var i = 1; i <= n; i++){    //  声明i为打印行数
            for(var k =1; k <= n - i; k++){     //声明k为打印空格
                document.write("&emsp;");
            }
            for(var f = 1; f <= 2*i - 1; f++){  //声明f为打印文字
                document.write("锋");
            }
            document.write("<br>");
        }
    }
    all(5);
    // 注意:  &nbsp;   不断行的空白(1个字符宽度)
    //        &ensp;     半个空白(1个字符宽度)
    //        &emsp;     一个空白(2个字符宽度)
    //        &thinsp;   窄空白(小于1个字符宽度)
    // 此处用的&emsp;相当于一个汉字宽度
    // 四、画一个菱形方案一
    //                         行数
    //         锋             j= 1     空格 4       锋    1
    //       锋锋锋          j= 2      空格 3        锋    3
    //     锋锋锋锋锋         j= 3      空格 2       锋    5
    //   锋锋锋锋锋锋锋       j = 4     空格 1       锋    7
    // 锋锋锋锋锋锋锋锋锋       j = 5    空格 0       锋    9
    //   锋锋锋锋锋锋锋                              空格5-j      锋   2*j-1
    //     锋锋锋锋锋
    //       锋锋锋
    //         锋 
    //  思路:做两个等腰三角形,一个朝上,一个朝下,下面的去掉一行,避免中间重复,因为菱形行数都是奇数
     function up(n){
        //  上面一个
        for(var i = 1; i <= n; i++){    //  声明i为打印行数
            for(var k =1; k <= n - i; k++){     //声明k为打印空格
                document.write("&emsp;");
            }
            for(var f = 1; f <= 2*i - 1; f++){  //声明f为打印文字
                document.write("锋");
            }
            document.write("<br>");
        }
        // 下面一个
        // 重点:首先行数要减一;第二,文字是从多一次减少,所以行数范围和自增自减要改变!
        for(var i = n - 1; i >= 1; i--){    //  声明i为打印行数
            for(var k =1; k <= n - i; k++){     //声明k为打印空格
                document.write("&emsp;");
            }
            for(var f = 1; f <= 2*i - 1; f++){  //声明f为打印文字
                document.write("锋");
            }
            document.write("<br>");
        }
    }
    up(9);
    //拓展  做一个空心菱形
    //         锋
    //        锋 锋
    //       锋   锋
    //      锋     锋
    //     锋       锋
    //    锋         锋
    //   锋           锋
    //  锋             锋
    // 锋               锋
    //  锋             锋
    //   锋           锋
    //    锋         锋
    //     锋       锋
    //      锋     锋
    //       锋   锋
    //        锋 锋
    //         锋
    
    function up(n) {
        //  上面一个
        for (var i = 1; i <= n; i++) {    //  声明i为打印行数
            for (var k = 1; k <= n - i; k++) {     //声明k为打印空格
                document.write("&emsp;");
            }
            for (var f = 1; f <= 2 * i - 1; f++) {  //声明f为打印文字
                // document.write("锋");
                if (f == 1 || f == 2 * i - 1) {    //当文字为第一个或最后一个时打印
                    document.write("锋");
                } else {                         //否则这一行其他为空
                    document.write("&emsp;");
                }
            }
            document.write("<br>");
        }
        // 下面一个
        // 重点:首先行数要减一;第二,文字是从多一次减少,所以行数范围和自增自减要改变!
        for (var i = n - 1; i >= 1; i--) {    //  声明i为打印行数
            for (var k = 1; k <= n - i; k++) {     //声明k为打印空格
                document.write("&emsp;");
            }
            for (var f = 1; f <= 2 * i - 1; f++) {  //声明f为打印文字
                // document.write("锋");
                if (f == 1 || f == 2 * i - 1) {     //当文字为第一个或最后一个时打印
                    document.write("锋");
                } else {                          //否则这一行其他为空
                    document.write("&emsp;");
                }
            }
            document.write("<br>");
        }
    }
    up(9);
    // 画一个菱形方案二
    // 思路:我们把菱形看成上下对称的阶梯
    //-4          锋               
    //-3        锋锋锋
    //-2      锋锋锋锋锋
    //-1    锋锋锋锋锋锋锋
    //0   锋锋锋锋锋锋锋锋锋
    //1     锋锋锋锋锋锋锋
    //2       锋锋锋锋锋
    //3         锋锋锋
    //4           锋
    // j=-4  空格   4    锋   9-2*4=1
    // j=-3  空格   3    锋   9-2*3=3
    // j=-2  空格   2    锋   9-2*2=5    
    // j=-1  空格   1    锋   9-2*1=7    
    // j=0   空格   0    锋   9-2*0=9    
    // j=1   空格   1    锋   9-2*1=7    
    // j=2   空格   2    锋   9-2*2=5   
    // j=3   空格   3    锋   9-2*3=3    
    // j=4   空格   4    锋   9-2*4=1    
    // 用到到方法:     Math.abs(-10)  => 10     取绝对值
    function center(n) {
        var mid = parseInt((n - 1) / 2); // =>  4  声明一个对称范围
        for(var i = -mid; i <= mid; i++){   //声明行数为-4
            for(var k = 1; k <= Math.abs(i); k++){  //声明k为空格数,小于等于行数的绝对值
                document.write("&emsp;");
            }
            for(var f = 1; f <= n - 2 * Math.abs(i); f++){  
                // 声明f为文字数,取值范围为:总行数 - 2 * 单行行数的绝对值
                document.write("锋");
            }
            document.write("<br>");
        }
    }
    center(9);
    // 此处有个小bug,实参取值必须是奇数!又菱形固有原理决定

用js写直角三角形,等腰三角形,菱形的更多相关文章

  1. Node.js写文件的三种方法

    Node.js写文件的三种方式: 1.通过管道流写文件 采用管道传输二进制流,可以实现自动管理流,可写流不必当心可读流流的过快而崩溃,适合大小文件传输(推荐) var readStream = fs. ...

  2. 用JS写了一个打字游戏,反正我是通不了关

    今天想写个简单的游戏, 打字游戏好像都没写过, 那么就写打字游戏吧, gamePad包含了关卡的信息, 可以用来调整给个关卡字符下落的速度: getRandom函数会返回一个字符对象, 这个对象包含了 ...

  3. JS写小游戏(一):游戏框架

    前言 前一阵发现一个不错的网站,都是一些用html5+css+js写的小游戏,于是打算学习一番,写下这个系列博客主要是为了加深理解,当然也有一些个人感悟,如果英文好可以直接Click Here. 概述 ...

  4. 去它的h5,我还是用js写原生跨平台app吧

    智能手机功能越来越强大,已经在逐渐替代电脑的作用.百度.腾讯.阿里的移动端日活数也在逐步的赶上甚至超越电脑端用户.叫喊着“mobile first”的公司越来越多,App开发者应运而生,且队伍日趋庞大 ...

  5. 原生js写的贪吃蛇网页版游戏特效

    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <bo ...

  6. 分享:计算机图形学期末作业!!利用WebGL的第三方库three.js写一个简单的网页版“我的世界小游戏”

    这几天一直在忙着期末考试,所以一直没有更新我的博客,今天刚把我的期末作业完成了,心情澎湃,所以晚上不管怎么样,我也要写一篇博客纪念一下我上课都没有听,还是通过强大的度娘完成了我的作业的经历.(当然作业 ...

  7. 原生 js 写分页

    欢迎留言或者加本人QQ172360937咨询 这段代码是用原生 js 写的一个分页的效果 <!doctype html> <html lang="en"> ...

  8. .NET获取不到js写的cookie解决方法

    今晚使用javascript设置一个来路的cookie,之后使用ASP.NET获取这个cookie值,发现ASP.NET获取不到JS设置的cookie值,真郁闷中,以下是JS写Cookie的代码: C ...

  9. js写的复制功能,只支持IE

    如果用js写,只能支持IE,如果想全支持,需要用jQuery的插件:jquery.zclip.js 下面是用js写的: var copyHref = function(){               ...

随机推荐

  1. 消除router-link 的下划线问题

    <div class="small-size"> <router-link to="/About"> <img src=" ...

  2. 程序员用于机器学习编程的Python 数据处理库 pandas 进阶教程

    数据访问 在入门教程中,我们已经使用过访问数据的方法.这里我们再集中看一下. 注:这里的数据访问方法既适用于Series,也适用于DataFrame. **基础方法:[]和. 这是两种最直观的方法,任 ...

  3. 搭建nextcloud私有云存储网盘

    简介: 搭建个人云存储一般会想到ownCloud,堪称是自建云存储服务的经典.而Nextcloud是ownCloud原开发团队打造的号称是“下一代”存储. 真正试用过后就由衷地赞同这个Nextclou ...

  4. apache虚拟主机配置的3种方式

    Apache的虚拟主机功能 (Virtual Host) 是可以让一台服务器基于IP.主机名或端口号实现提供多个网站服务的技术. 下面我介绍一下这3种方式具体的配置流程: 一.基于ip地址 首先我们需 ...

  5. VisualStudio2012编辑器错误

    https://blogs.msdn.microsoft.com/webdev/2014/11/11/dialog-box-may-be-displayed-to-users-when-opening ...

  6. ant 自动化构建环境。

    ant  一个自动化构建的工具 可以帮你实现自动化打包和发布到web环境上. 项目目录如下: 项目一:common-framework 项目二:estun-platform-web 其中项目一是项目二 ...

  7. Could not resolve dependencies for project, Failed to read artifact descriptor for

    一个可能的原因是由于你的网络从局域网(比如实验室网)切换到了代理网络(比如校园公共网). 方法一:重新切换到非代理网络 办法二:repository 或 dependency 名称不对,比如新repo ...

  8. JSP + Session Cookie详解

    篇幅较大,对JSP进行了非常详细的讲解,并解释了Session和Cookie的实现原理 ,预计看完需要20分钟左右,慢慢享受吧 JSP概述 掌握了servlet后,就可以利用servlet来开发动态页 ...

  9. iOS本地数据存储

    http://www.jianshu.com/p/a3eeae99e902 大牛整理的超全

  10. 移动前端不得不了解的HTML5 head 头标签 —— Meta 标签

    Meta 标签 meta标签是HTML中head头部的一个辅助性标签,它位于HTML文档头部的 <head> 和 <title> 标记之间,它提供用户不可见的信息.虽然这部分信 ...