JavaScript实现打印星型金字塔功能实例分析


Posted in Javascript onSeptember 27, 2017

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

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

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

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

JavaScript实现打印星型金字塔功能实例分析

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

因为要是放在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由于在我的电脑里面感觉还可以,所以才定这个数的,没有什么特别的意义,乱输入的,不是故意测试的。

JavaScript实现打印星型金字塔功能实例分析

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

运行结果如下:

JavaScript实现打印星型金字塔功能实例分析

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

二、基本思想

这个弄懂就非常好写了。

JavaScript实现打印星型金字塔功能实例分析

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

分两部分,一部分是上半部分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程序设计有所帮助。

Javascript 相关文章推荐
网页防止tab键的使用快速解决方法
Nov 07 Javascript
jQuery学习笔记之总体架构
Jun 03 Javascript
javascript高级编程之函数表达式 递归和闭包函数
Nov 29 Javascript
JS定时器使用,定时定点,固定时刻,循环执行详解
May 31 Javascript
浅析bootstrap原理及优缺点
Mar 19 Javascript
JS常用正则表达式总结【经典】
May 12 Javascript
Vue props用法详解(小结)
Jul 03 Javascript
微信自定义分享链接信息(标题,图片和内容)实现过程详解
Sep 04 Javascript
微信小程序 this.triggerEvent()的具体使用
Dec 10 Javascript
JavaScript代理模式原理与用法实例详解
Mar 10 Javascript
JS如何寻找数组中心索引过程解析
Jun 01 Javascript
jQuery实现简单轮播图效果
Dec 27 jQuery
微信小程序 按钮滑动的实现方法
Sep 27 #Javascript
详解Vue-cli代理解决跨域问题
Sep 27 #Javascript
jQuery 利用ztree实现树形表格的实例代码
Sep 27 #jQuery
javascript 作用于作用域链的详解
Sep 27 #Javascript
深入理解Vue2.x的虚拟DOM diff原理
Sep 27 #Javascript
bootstrap table实现双击可编辑、添加、删除行功能
Sep 27 #Javascript
Three.js中网格对象MESH的属性与方法详解
Sep 27 #Javascript
You might like
php标签云的实现代码
2012/10/10 PHP
redirect_uri参数错误的解决方法(必看)
2017/02/16 PHP
转一个日期输入控件,支持FF
2007/04/27 Javascript
javascript闭包的高级使用方法实例
2013/07/04 Javascript
jquery 按钮状态效果 正常、移上、按下
2013/08/12 Javascript
JS的get和set使用示例
2014/02/20 Javascript
jQuery实现为图片添加镜头放大效果的方法
2015/06/25 Javascript
JavaScript使用DeviceOne开发实战(一) 配置和起步
2015/12/01 Javascript
详解webpack解惑:require的五种用法
2017/06/09 Javascript
Vue-resource拦截器判断token失效跳转的实例
2017/10/27 Javascript
react 实现页面代码分割、按需加载的方法
2018/04/03 Javascript
JS实现快递单打印功能【推荐】
2018/06/21 Javascript
微信小程序列表中item左滑删除功能
2018/11/07 Javascript
vue 基于element-ui 分页组件封装的实例代码
2018/12/10 Javascript
Vue 表情包输入组件的实现代码
2019/01/21 Javascript
Javascript摸拟自由落体与上抛运动原理与实现方法详解
2020/04/08 Javascript
微信小程序自定义胶囊样式
2020/12/27 Javascript
[54:25]Ti4 循环赛第三日LGD vs MOUZ
2014/07/12 DOTA
[00:19]CN DOTA NEVER DIE!VG夺冠rOtK接受采访
2019/12/23 DOTA
Django rest framework基本介绍与代码示例
2018/01/26 Python
Python输出由1,2,3,4组成的互不相同且无重复的三位数
2018/02/01 Python
Python3 获取一大段文本之间两个关键字之间的内容方法
2018/10/11 Python
python 环境搭建 及python-3.4.4的下载和安装过程
2019/07/20 Python
Python实现决策树并且使用Graphviz可视化的例子
2019/08/09 Python
使用pickle存储数据dump 和 load实例讲解
2019/12/30 Python
运行tensorflow python程序,限制对GPU和CPU的占用操作
2020/02/06 Python
Python API len函数操作过程解析
2020/03/05 Python
python学习之使用Matplotlib画实时的动态折线图的示例代码
2021/02/25 Python
pyx文件 生成pyd 文件用于 cython调用的实现
2021/03/04 Python
IE矩阵Matrix滤镜旋转与缩放及如何结合transform
2012/11/29 HTML / CSS
阳光体育:Sunny Sports(购买露营和远足设备)
2018/08/07 全球购物
企业厂长岗位职责
2013/12/17 职场文书
工程售后服务承诺书
2014/05/21 职场文书
机电一体化应届生求职信
2014/08/09 职场文书
社区两委对照检查材料
2014/08/23 职场文书
2016年八一建军节活动总结
2016/04/05 职场文书