//一、 画一个直角三角形
    // 第几行   *号数
    // *        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. 前端页面传来数组,后台用对象集合list接收数据的写法

    //保存页面显示应用$("#save").click(function(){ var data = [{"applicationtypeid":"65 ...

  2. 解决django或者其他线程中调用scrapy报ReactorNotRestartable的错误

    官网中关于ReactorNotRestartable的错误描述(摘自:https://twistedmatrix.com/documents/16.1.0/api/twisted.internet.e ...

  3. ansible start canal

    - name: Start canal server shell: source /etc/profile && nohup /opt/canal/bin/startup.sh

  4. 扛把子组final week 1/1 Scrum立会报告+燃尽图 01

    此作业的要求参见http://edu.cnblogs.com/campus/nenu/2019fall/homework/10065 一.小组情况 队名:扛把子 组长:孙晓宇 组员:宋晓丽 梁梦瑶 韩 ...

  5. springboot整合netty的多种方式

    netty作为一个高性能的io框架,是非好用的一个技术框架, Netty 是一个基于NIO的客户.服务器端编程框架,使用Netty 可以确保你快速和简单的开发出一个网络应用,例如实现了某种协议的客户. ...

  6. Hbase初识

    简介 数据模型 相关数据库 典型应用 优势 劣势 key-value Redis 缓存 快速查询 存储数据缺乏结构化 列族 Cassandra,Hbase 分布式的文件系统,大规模的数据存储 易于分布 ...

  7. SQL Server2017 安装完成后找不到启动项解决方案

    很多用于当SQL Server2017 安装完成后开始菜单找不到启动项无法启动SQL Server2017 其实你只需要安装一下SSMS-Setup-CHS就可以了 安装完成之后就有了 SSMS-Se ...

  8. CentOS 7 安装 bind 服务 实现内网DNS

    目录 安装 配置 服务管理 测试 安装 废话不多说,直接安装 yum install -y bind bind-utils 配置 [root@jenkins named]# rpm -ql bind ...

  9. 监控io性能、free、ps命令、查看网络状态、Linux下抓包 使用介绍

    第7周第2次课(5月8日) 课程内容: 10.6 监控io性能 10.7 free命令10.8 ps命令10.9 查看网络状态10.10 linux下抓包扩展tcp三次握手四次挥手 http://ww ...

  10. 2019-2020-12 20199317 《Linux内核原理与分析》 第十二周作业

    SET-UID程序漏洞实验 1  实验简介 Set-UID 是 Unix 系统中的一个重要的安全机制.当一个 Set-UID 程序运行的时候,它被假设为具有拥有者的权限.例如,如果程序的拥有者是roo ...