>웹 프론트엔드 >JS 튜토리얼 >JavaScript 인쇄 스타 피라미드 기능

JavaScript 인쇄 스타 피라미드 기능

小云云
小云云원래의
2018-01-30 13:19:473469검색

이 글에서는 별 피라미드 인쇄 기능을 구현하기 위한 JavaScript를 주로 소개합니다. 특정 예제를 기반으로 임의의 행 수로 별 피라미드 그래픽을 출력하는 JavaScript의 원리와 관련 구현 기술을 분석합니다. 모든 사람에게 도움이 되기를 바랍니다.

다른 언어로 글을 쓸 때도 같은 원칙이 적용됩니다.

C 언어를 배울 때 이 질문을 본 적이 있을 것 같습니다...

즉, 다음과 같은 유령을 인쇄하는 것입니다.

보세요. 그 당시 루프 구조에 왔을 때 너무 지루해서 이 질문을 무시하고 신중하게 생각하지 않았습니다.

자바스크립트로 넣으면 이렇게 작성할 수 없기 때문입니다. 심지어 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 및 * 글꼴 처리가 조판 혼란을 야기하기 때문입니다. 즉, 표준 Song 글꼴은 그렇지 않습니다. 사용되어 최종 결과를 볼 수 없게 됩니다.

아무튼 위 내용은 몇 줄을 올려도 복사해서 붙여넣을 수 있는데, 오늘은 어느 정도 프로그래밍을 하고 빅데이터 개념을 잡게 되면서 이 질문을 다시 보고 곰곰히 생각하게 되었습니다. 질문한 사람이 중심축에 20만 개의 대칭선이 있는 별 모양의 피라미드를 출력하라고 하면 나는 저주받을 것입니다.

그러므로 이를 구현하는 방법을 완전히 이해해야 합니다. 실제 프로그래밍에서는 이러한 프로그래밍이 발생하지 않지만 적어도 후발자가 C 언어에 대해 묻는 경우 이러한 질문이 계속 발생한다고 합니다. 중심축 대칭이 200,000줄인 별 모양의 피라미드를 출력하더라도 처음에 이 질문을 할 수 없다면 어떻게 해야 할지 알아야 합니다.

1. 기본 목표

먼저 입력 상자가 나타나고 사용자가 홀수를 입력할 수 있습니다. 결국 축 대칭에는 홀수가 필요합니다. 그러면 프로그램의 견고성은 무엇입니까? 사용자 입력을 판단해야 합니다. 입력이 홀수가 아니면 프롬프트가 나타나고 후속 프로그램이 실행되지 않습니다. JavaScript를 사용하여 홀수를 결정하는 방법은 "JavaScript의 판단 및 처리"에서 이미 언급했습니다. 숫자'에 대해서는 여기서 자세히 설명하지 않겠습니다.

여기에서는 브라우저의 부하를 고려하여 사용자가 입력하는 홀수만 189로 허용합니다. 189를 늘려도 괜찮다고 생각해서 이 숫자로 설정했습니다. . 특별한 의미는 의도적인 테스트가 아닌 무작위 입력입니다.

189 줄을 입력하면 IE는 이미 "스크립트를 중단하세요"라는 프롬프트를 띄웠지만 중단하지 않으면 문제가 없습니다!

실행 결과는 다음과 같습니다.

C 언어 프로그램이나 다른 프로그램을 작성하는 경우 이 값은 확실히 더 크게 설정할 수 있습니다!

2. 기본 아이디어

이것을 이해하고 나면 작성하기가 매우 쉽습니다.

먼저 *의 왼쪽에 공백만 출력하면 되고, 오른쪽에는 공백을 출력할 필요가 없이, *를 입력한 후 바로 줄을 바꿔주시면 됩니다

로 나누어져 있습니다. 두 부분으로, 한 부분은 위쪽 부분 i028d6d0408fd6da2cd9be3b473560d98n/2일 때입니다.

가 이렇게 구분되는 이유는 이 두 부분에 의해 출력되는 * 기호 때문입니다. 부품과 출력되는 공간의 수가 다릅니다.

이후 규칙을 찾는 것은 중학교 시절 흔한 문제였는데, 아무튼 위의 규칙을 찾았고, 프로그래밍할 때 문제가 없었는데, 다른 수학 황제들이 더 멋진 표현을 찾아냈고, 저는 패배했습니다.

3. 제작 과정

코드는 매우 간단합니다. 위의 개념을 이해하면 말할 것도 없이 조건부 구조와 루프 구조를 표현한 것입니다.

어떤 사람들은 여기서 이상하다고 생각할 수도 있는데 왜 n++을 먼저 판단한 다음 n%2!=0, 즉 n이 홀수인지 판단하기 위해 n+1이 짝수인지 판단해야 합니까?

이것은 주로 다음 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 방법(Jquery)

웹 페이지 콘텐츠의 일부를 인쇄하는 Javascript 스크립트_javascript Skill

iframe 콘텐츠 샘플 코드를 인쇄하는 JavaScript_javascript 팁

위 내용은 JavaScript 인쇄 스타 피라미드 기능의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.