本文实例讲述了JavaScript实现打印星型金字塔功能。分享给大家供大家参考,具体如下:

让你用其它语言写也是完全一样的道理,

这道题估计大家在学习C语言的时候就见过……

也就是打印以下的鬼东西:

当时候看到循环结构的时候觉得很无聊,就相当不屑这题,没有好好仔细想想,

因为要是放在JavaScript完全可以这样写,甚至还不算是JavaScript,仅仅就是一个html:

  *

 ***

*****

 ***

  *

这里之所以不用utf-8编码是因为utf-8对于nbsp的处理与*的字体会导致排版错乱,就是不是用标准的宋体字,从而导致最终的结果无法查看。

反正你出题人出多少行,我都可以复制粘贴上面的内容完全可以实现,但是,今天编程编到一定量,有点大数据概念的时候,又见到这题,仔细思考了一下,要是出题人要求输出二十万行这样中间轴对称的星型金字塔,我TMD就呵呵了。

所以还是要彻底搞明白这个怎么实现,虽然在实际的编程中不会出现这样的编程,但是,据说一些无聊的面试还是会出这题,至少,后来者问你C语言的时候,问你如果输出二十万行这样的中间轴对称的星型金字塔,你还是要会,这题如果第一次做不好做的。

一、基本目标

首先弹出一个输入框,让用户输入一个奇数,毕竟轴对称需要一个奇数,

然后为了程序的健壮性,必须对用户输入的东西进行判断,如果输入的不是奇数,就弹出提示,不再执行后面的程序,怎么JavaScript判断一个奇数,我已经在《JavaScript对数字的判断与处理》说过,这里不再进行赘述。

考虑到浏览器的负载,这里,用户输入的奇数,我只允许去到189,你调大一点也可以,189由于在我的电脑里面感觉还可以,所以才定这个数的,没有什么特别的意义,乱输入的,不是故意测试的。

输入一个189行,IE已经弹出“中止脚本”的提示了,但不中止也完全没有问题!

运行结果如下:

如果是在写C语言程序或者其他程序,这个值绝对可以定大一点!

二、基本思想

这个弄懂就非常好写了。

首先,我们仅仅是要在*的左边输出空格,右边就没有必要输出空格了,输完*就直接换行

分两部分,一部分是上半部分i<=n/2的时候,另一部分是下半部分i>n/2的时候,

之所以要这样分是因为这两部分输出的*号与输出的空格数是不同的。

之后就是初中都会的找规律问题了,反正我就找到了如上的规律,编程运行时没有问题,其它数学帝找到更牛B的表达式,小弟甘拜下风。

三、制作过程

代码非常简单,就是条件结构与循环结构的表达,上面的思想弄懂了,不用说了。

这里可能会有人觉得奇怪,为何我要先n++然后n%2!=0再来判断,也就是判断n+1是偶数来判断n是否奇数,

这里主要是为了迎合下面的for循环结构……

var i,j,k,n;

n=window.prompt("请输入要输出的行数n,为了形成轴对称,所以你输出的必须是奇数!");

if(isNaN(n)||!n)

alert("你输入的不是数!");

else{

n++;

if(n%2!=0)

alert("你输入的不是奇数!");

else if(n>190){

alert("不要这么大嘛!臣妾做不到啊!");

}

else{

for(i=1;i

if(i<=n/2){

for(k=n/2-i;k>0;k--)

document.write("&nbsp;");

for(j=0;j<2*i-1;j++)

document.write("*");

}

else{

for(k=i-n/2;k>0;k--)

document.write("&nbsp;");

for(j=0;j<2*(n-i)-1;j++)

document.write("*");

}

document.write("
");

}

}

}

说多了也是泪,自己体会……

希望本文所述对大家JavaScript程序设计有所帮助。

jsp输出金字塔_JavaScript实现打印星型金字塔功能实例分析相关推荐

  1. java打印星型_使用java打印心型、圆形图案的实现代码

    相信对于打印三角形都没什么难度,只需要利用for循环嵌套使用就行 但是对于打印圆形和三角形不同因为到圆心距离相等的点一般不会横坐标和纵坐标都为整数 打印爱心 爱心的公式 (x²+y²-1)³-x²*y ...

  2. java打印星型_初识java java入门知识 基础知识 打印各种星型图形 源代码

    今天给大家带来的是初级Java基础部分的知识:包括初识Java.变量.常量.数据类型.运算符.各种选择结构.循环结构.数组等Java的基础语法部分!最后还有****循环结构的进阶****,步骤超详细, ...

  3. jsp中用java写标签id_jsp中自定义标签用法实例分析

    本文实例讲述了jsp中自定义标签用法.分享给大家供大家参考.具体如下: 这里简单的写了一个自定义标签,自己定义标签的好处就是在jsp页面中可以使用自己定义的功能,完全与Java代码分离 1. tld文 ...

  4. FocusBI:租房分析星型模型

    微信公众号:FocusBI 关注可了解更多的商业智能.数据仓库.数据库开发.爬虫知识及沪深股市数据推送.问题或建议,请关注公众号发送消息留言; 如果你觉得FocusBI对你有帮助,欢迎转发朋友圈或在文 ...

  5. java心形代码_使用java打印心型、圆形图案的实现代码_java

    相信对于打印三角形都没什么难度,只需要利用for循环嵌套使用就行 但是对于打印圆形和三角形不同因为到圆心距离相等的点一般不会横坐标和纵坐标都为整数 打印爱心 爱心的公式 (x²+y²-1)³-x²*y ...

  6. 计算机网络拓扑结构 以下关于星型网络拓扑结构的描述正确的是______。 (多选题 )

    题目和答案在最下面! 全文转自百度,自己总结方便自己以后查找! 常见类型: 星型拓扑 总线拓扑 ▪ 环型拓扑 ▪ 树型拓扑 ▪ 混合型拓 ▪ 网型拓扑 开关电源拓扑 简单介绍的: 星型 优点:可靠性高 ...

  7. 多重循环 ——— 打印九九乘法表 || 经典的打印金字塔(打印整个金字塔 打印空心金字塔 打印空心菱形金字塔)

    打印九九乘法表 分析:每层左边空格的个数=总层数-第几层(i) 每一层的第一个*的位置是   1               每一层的最后一个*的位置是  2i-1 ​ #include <st ...

  8. CIKM 2021 | 多场景下的星型CTR预估模型STAR

    ▐ 摘要 阿里妈妈展示广告需要为大量的场景提供广告排序能力,在业务场景数急剧膨胀的背景下,我们开始研究多场景联合建模.本篇文章主要介绍,我们在多场景建模下遇到的挑战.挑战背后的思考以及算法工程 co- ...

  9. LeetCode 1791. 找出星型图的中心节点(图出入度)

    文章目录 1. 题目 2. 解题 1. 题目 有一个无向的 星型 图,由 n 个编号从 1 到 n 的节点组成. 星型图有一个 中心 节点,并且恰有 n - 1 条边将中心节点与其他每个节点连接起来. ...

最新文章

  1. 找出1个小时前更新的文件并进行拷贝
  2. ORACLE 创建作业JOB例子
  3. 新手python爬虫代码_新手小白必看 Python爬虫学习路线全面指导
  4. 画好原理图的几个技巧
  5. sql server datetime取年月_快速定位数据库性能问题,RDS推出慢SQL统计分析
  6. 中芯国际发布2021Q1财报:55/65纳米工艺依旧为营收主力
  7. 【恋上数据结构】基数排序、桶排序、休眠排序
  8. linux内核数据链路层,Linux网络内核数据帧的接收进程:数据链路层(概念篇)...
  9. 《Java技术》预备作业总结
  10. 自动驾驶3-3 自动驾驶的安全框架 Safety Frameworks for Self-Driving
  11. 文本框改变之onpropertychange事件
  12. U盘启动盘cmd制作
  13. apt-get 安装失败:Unable to correct problems, you have held broken packages
  14. python tkinter 按钮 Button增加图片
  15. 【SpringCloud】 - Feign 踩坑记录:404 ,调用不成功 , 接口定义规范 等问题记录
  16. 在Excel中如何提取括号中的数字
  17. JVM - 垃圾回收(垃圾标记阶段算法,内存泄漏与溢出)(2)
  18. 【个人博客】Hexo个人博客搭建与配置详细教程 + Fluid主题 + Gitee发布
  19. 如何制作打首板的量化策略
  20. 使用.net编写的 短连接(短网址)服务

热门文章

  1. 没有个性化如何设置桌面计算机,w7桌面没有个性化怎么办_w7桌面个性化不见了如何解决...
  2. 极米如果上市,坚果、小米、当贝们会迎来狂欢吗?
  3. 杂谈:英雄联盟的惩罚与游戏态度
  4. SpringBoot整合Redis缓存
  5. 移动端WEB开发——响应式布局
  6. 浅析Oracle等待事件
  7. 鼠标案例2-鼠标移动监听
  8. 富康/爱丽舍换挡时机
  9. java8 手把手教你学会写lambda表达式
  10. 主流布局--双飞翼布局