繁体   English   中英

使用JS循环形成倒置的ascii三角图

[英]Forming an inverted ascii triangle art using JS looping

没有嵌套循环,您如何形成这样的ascii艺术?

####
###
##
#

这是我目前拥有的:

function invertTriangle (row) {
  var asteric = "*" * row;
  for ( var y=row; y>=row; y--){
      asteric = asteric - "*";
      console.log(asteric);
  }
};

invertTriangle(10);

感谢您的帮助和解释!

谢谢!

尝试:

 var string = ""; for (var i = 0, j = 4, k = 4; i < 10; i++) { string += "*"; if (--j === 0) { j = --k; string += "\\n"; } } alert(string); 

希望能有所帮助。

这是使用递归的一种方法。

基本上,您以第一行中要打印的字符数调用该函数。 然后,它构造一个包含这么多字符的字符串。 然后,它减少所需的字符数,如果该字符数大于0,则再次调用自身并将新结果添加到当前结果中。 这一直持续到我们到达需要零个字符的行为止。 此时,该函数不再调用自身,并且将完全构造的字符串返回给原始调用者。

码:

<!DOCTYPE html>
<html>
<head>
<script>
"use strict";
function byId(e){return document.getElementById(e);}

window.addEventListener('load', onDocLoaded, false);

function onDocLoaded()
{
    byId('triTgt').innerText = makeTriString(40);
}

function makeTriString(nStars)
{
    var str = '';
    for (var i=0; i<nStars; i++)
        str += "*";
    str += "\n";
    nStars--;
    if (nStars > 0)
        str += makeTriString(nStars);
    return str;
}
</script>
<style>
</style>
</head>
<body>
    <div id='triTgt'></div>
</body>
</html>

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM