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

让你用其它语言写也是完全一样的道理,
这道题估计大家在学习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相关内容感兴趣的读者可查看本站专题:《JavaScript数学运算用法总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript数组操作技巧总结》、《JavaScript排序算法总结》、《JavaScript遍历算法与技巧总结》、《JavaScript查找算法技巧总结》及《JavaScript错误与调试技巧总结》
希望本文所述对大家JavaScript程序设计有所帮助。
# JavaScript
# 打印
# 星型
# 金字塔
# jsvascript图像处理—(计算机视觉应用)图像金字塔
# javascript 打印内容方法小结
# js 实现打印网页中定义的部分内容的代码
# javascript打印输出json实例
# jsp/javascript打印九九乘法表代码
# javascript 局部页面打印实现代码
# js fromCharCode输出26个字母的代码
# js循环输出图片
# 不足的要补0
# javascript实现输出指定行数正方形图案的方法
# 弹出
# 是因为
# 二十
# 问你
# 两部分
# 我就
# 是在
# 放在
# 相关内容
# 还可以
# 我都
# 说了
# 我只
# 见过
# 还不
# 遍历
# 说过
# 要在
# 感兴趣
# 没有什么
相关文章:
早安海报制作网站推荐大全,企业早安海报怎么每天更换?
如何在宝塔面板中创建新站点?
高防服务器租用如何选择配置与防御等级?
盐城做公司网站,江苏电子版退休证办理流程?
网站网页制作专业公司,怎样制作自己的网页?
c# 在高并发场景下,委托和接口调用的性能对比
如何快速生成专业多端适配建站电话?
建站主机选哪家性价比最高?
制作网站哪家好,cc、.co、.cm哪个域名更适合做网站?
太平洋网站制作公司,网络用语太平洋是什么意思?
怎么用手机制作网站链接,dw怎么把手机适应页面变成网页?
建站之星安装失败:服务器环境不兼容?
如何在Windows虚拟主机上快速搭建网站?
C++中的Pimpl idiom是什么,有什么好处?(隐藏实现)
上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的?
大连网站制作费用,大连新青年网站,五年四班里的视频怎样下载啊?
北京制作网站的公司排名,北京三快科技有限公司是做什么?北京三快科技?
建站主机是否属于云主机类型?
建站主机核心功能解析:服务器选择与网站搭建流程指南
青岛网站建设如何选择本地服务器?
小米网站链接制作教程,请问miui新增网页链接调用服务有什么用啊?
如何选择可靠的免备案建站服务器?
如何通过可视化优化提升建站效果?
微信h5制作网站有哪些,免费微信H5页面制作工具?
如何通过云梦建站系统实现SEO快速优化?
专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?
如何在云主机快速搭建网站站点?
三星网站视频制作教程下载,三星w23网页如何全屏?
建站之星2.7模板:企业网站建设与h5定制设计专题
山东云建站价格为何差异显著?
如何安全更换建站之星模板并保留数据?
招贴海报怎么做,什么是海报招贴?
建站之星后台密码如何安全设置与找回?
建站之星各版本价格是多少?
网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?
建站之星如何快速解决建站难题?
道歉网站制作流程,世纪佳缘致歉小吴事件,相亲网站身份信息伪造该如何稽查?
如何选择CMS系统实现快速建站与SEO优化?
C#如何序列化对象为XML XmlSerializer用法
网站制作公司排行榜,抖音怎样做个人官方网站
广州建站公司哪家好?十大优质服务商推荐
深入理解Android中的xmlns:tools属性
高性价比服务器租赁——企业级配置与24小时运维服务
邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?
c# 在高并发下使用反射发射(Reflection.Emit)的性能
如何高效利用200m空间完成建站?
网站按钮制作软件,如何实现网页中按钮的自动点击?
岳西云建站教程与模板下载_一站式快速建站系统操作指南
网站好制作吗知乎,网站开发好学吗?有什么技巧?
天河区网站制作公司,广州天河区如何办理身份证?需要什么资料有预约的网站吗?
*请认真填写需求信息,我们会在24小时内与您取得联系。