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

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

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

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

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

<html>
<head>
<meta http-equiv="content-type" content="text/html;charset=gb2312"/>
</head>
<body>
&nbsp;&nbsp;*
&nbsp;***
*****
&nbsp;***
&nbsp;&nbsp;*
</body>
</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循环结构……

<html>
<head>
<meta http-equiv="content-type" content="text/html;charset=gb2312"/>
</head>
<body>
</body>
</html>
<script>
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<n;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("<br>");}}}</script>

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

【JavaScript】打印星型金字塔相关推荐

  1. jsp输出金字塔_JavaScript实现打印星型金字塔功能实例分析

    本文实例讲述了JavaScript实现打印星型金字塔功能.分享给大家供大家参考,具体如下: 让你用其它语言写也是完全一样的道理, 这道题估计大家在学习C语言的时候就见过-- 也就是打印以下的鬼东西: ...

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

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

  3. 用JavaScript打印三角形、金字塔型

    首先,这张图的三角效果为每打印一行,*都会比上一行多一 思路分析:第一行一个,第二行两个,第三行三个,那么,第n行就是n个了 function star() { //用prompt来实现想要打印几行便 ...

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

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

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

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

  6. Day3 : zigbee无线传感器网络管理之星型网络

    Day3 : zigbee无线传感器网络管理之星型网络 基于广播和单播的星状网络 网络拓扑结构 功能要求 实现过程 组播通信 功能要求 实现过程 串口无线透传实验 基于 Z-Stack 的串口通信 功 ...

  7. Oracle优化器:星型转换

    Oracle 8i中引入了星型转换(star transformation)的优化器新特性以便更有效地处理星型查询.星型查询语句多用于基于星型模型设计的数据仓库应用中.星型模型的称谓源于该种模型以图形 ...

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

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

  9. bootstrap五星评分_星型打分插件 bootstrap-rating-input

    最近帮人实现一个打分的功能,发现bootstrap-rating-input是个简单又好用的星型打分,我对其做了些定制,添加了分值说明,并修改了样式,毕竟 bootstrap 自身的黑色五角星还是不够 ...

  10. 多数据中心的高可用结构【环状星型数据库架构】

    贴一些比较老的内容,文章是新写的,技术可能都是大家熟悉的,给入门的兄弟们参考.高手轻拍 原文请见:http://www.muduo.net/index.php/u ... space-itemid-3 ...

最新文章

  1. ros知识:关于catkin_init_workspace不能执行的错误
  2. 【AC自动机】AC自动机(二次加强版)(luogu 5357)
  3. 是什么东西_隐形牙套附件是什么东西?
  4. 缓存,你真的用对了么?
  5. A - C语言实验——最值
  6. java多线程系类:JUC原子类:04之AtomicReference原子类
  7. 军营中重重打击之后,我变了一个人(中)--我成为程序员所经历的(四)
  8. mysql alter 增加修改表结构及约束
  9. Python3练习题系列(03)
  10. 事情又没有后续,吾真想质问头目,汝是为吾干活吗?
  11. spyder python下载_Spyder python下载
  12. SAT数学公式之几何图形
  13. 硬盘结构及raid磁盘阵列
  14. r语言中trifit怎么用_R语言中的stargazer包的使用方法
  15. 69.46.68.92 index.php,【英联雅思】搞定四六级又战托福雅思?先测测自己的词汇量有多少吧~...
  16. Android 屏幕旋转的处理
  17. 沟通的艺术(笔记)——前言
  18. 如何打造爆款付费文章
  19. Win10修改msconfig后无法开机怎么办?
  20. 2015年度汽车客运站现状分析及未来趋势发展报告

热门文章

  1. C#微信公众号与订阅号接口开发示例代码
  2. 如何查找一篇论文的源代码
  3. 【软件定义汽车】AUTOSAR架构介绍
  4. 抢食生鲜,美团最大对手会是拼多多
  5. kinect面部捕捉_脸部登录Windows 10-在Windows Hello中使用Xbox One Kinect
  6. 【Chrome】浏览器控制台设置成中文
  7. 怎样了解存在---辩证唯物主义认识论
  8. 利用Python自动生成小学生加减乘除口算考试题卷
  9. mysql查询语句创建临时表_MySQL 临时表_mysql临时表创建_mysql临时表创建
  10. 基于cnn的人脸识别_人脸识别技术:从传统方法到深度学习