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 相关文章推荐
javascript iframe编程相关代码
Dec 28 Javascript
jQuery滚动条插件nanoscroller使用指南
Apr 21 Javascript
jQuery 弹出层插件(推荐)
May 24 Javascript
JavaScript函数节流概念与用法实例详解
Jun 20 Javascript
JS返回只包含数字类型的数组实例分析
Dec 16 Javascript
jQuery插件FusionCharts绘制的3D双柱状图效果示例【附demo源码】
Apr 20 jQuery
jQuery动画_动力节点节点Java学院整理
Jul 04 jQuery
JS处理数据四舍五入(tofixed与round的区别详解)
Oct 26 Javascript
详解服务端预渲染之Nuxt(介绍篇)
Apr 07 Javascript
使用vue实现通过变量动态拼接url
Jul 22 Javascript
OpenLayer3自定义测量控件MeasureTool
Sep 28 Javascript
JavaScript 中for/of,for/in 的详细介绍
Nov 17 Javascript
微信小程序 按钮滑动的实现方法
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
ThinkPHP进程计数类Process用法实例详解
2015/09/25 PHP
php高性能日志系统 seaslog 的安装与使用方法分析
2020/02/29 PHP
js中的window.open返回object的错误的解决方法
2009/08/15 Javascript
JQuery 1.3.2以上版本中出现pareseerror错误的解决方法
2011/01/11 Javascript
JS 屏蔽按键效果与改变按键效果的示例代码
2013/12/24 Javascript
Javascript 按位与赋值运算符 (&amp;=)使用介绍
2014/02/04 Javascript
JS实现很酷的EMAIL地址添加功能实例
2015/02/28 Javascript
Angular 路由route实例代码
2016/07/12 Javascript
AngularJs  Using $location详解及示例代码
2016/09/02 Javascript
浅谈jquery.form.js的ajaxSubmit和ajaxForm的使用
2016/09/09 Javascript
jquery根据td给相同tr下其他td赋值的实现方法
2016/10/05 Javascript
jQuery EasyUI 右键菜单--关闭标签/选项卡的简单实例
2016/10/10 Javascript
使用jQuery.Pin垂直滚动时固定导航
2017/05/24 jQuery
ReactNative Image组件使用详解
2017/08/07 Javascript
Angular实现双向折叠列表组件的示例代码
2017/11/21 Javascript
基于vue中css预加载使用sass的配置方式详解
2018/03/13 Javascript
vue-router3.0版本中 router.push 不能刷新页面的问题
2018/05/10 Javascript
axios如何利用promise无痛刷新token的实现方法
2019/08/27 Javascript
mpvue 页面预加载新增preLoad生命周期的两种方式
2019/10/17 Javascript
vue 中url 链接左边的小图标更改问题
2019/12/30 Javascript
js实现贪吃蛇游戏(简易版)
2020/09/29 Javascript
[01:52]DOTA2完美大师赛Vega战队趣味视频——kpii老师小课堂
2017/11/25 DOTA
9种python web 程序的部署方式小结
2014/06/30 Python
Python-jenkins模块获取jobs的执行状态操作
2020/05/12 Python
Mysql数据库反向生成Django里面的models指令方式
2020/05/18 Python
django 模型中的计算字段实例
2020/05/19 Python
如何理解python对象
2020/06/21 Python
matplotlib常见函数之plt.rcParams、matshow的使用(坐标轴设置)
2021/01/05 Python
机电一体化专业应届生求职信
2013/11/27 职场文书
大学生涯自我鉴定
2014/01/16 职场文书
中学教师培训制度
2014/01/31 职场文书
住院医师规范化培训实施方案
2014/06/12 职场文书
公司市场专员岗位职责
2014/06/29 职场文书
家庭贫困证明范本(经典版)
2014/09/22 职场文书
解除同居协议书
2015/01/29 职场文书
eclipse创建项目没有dynamic web的解决方法
2021/06/24 Java/Android