lsdsg 发表于 2021-10-7 21:34:26

菱形字母塔

本帖最后由 lsdsg 于 2021-10-7 21:37 编辑

【问题描述】

根据输入的整数n,输出对称的菱形字母塔。该字母塔有2*n-1行,每一行有若干个空格字符和大写英文字母组成。



【输入形式】

输入一个自然数n(1<=n<=26)


【输出形式】
输出由2*n-1行大写英文字母和空格组成的字母塔,其规律请见样例输出。其中的第n行最左面没有空格,每一行的右侧也没有空格。



【样例输入1】

4


【样例输出1】

http://programming.cqu.edu.cn/userfiles/image/2021/1612107613337045226.jpg


【样例输入2】

8


【样例输出2】

http://programming.cqu.edu.cn/userfiles/image/2021/1612107625884031177.jpg

jhq999 发表于 2021-10-8 07:45:09

int n=7,m=0,k=0;
        n=2*n-1;
        int i = 0,j=0;

        for (int i = 0; i < n; i++)
        {
                m=i;
                if (i>(n/2))
                {
                        m=(n-m-1);
                }
                k=0;
                for (int j = 0; j < n; j++)
                {
                        if ((j>=(n/2-m))&&(j<=(n/2+m)))
                        {
                               
                                printf("%c",'A'+k);
                                if (j>(n/2-1))
                                {
                                        k--;
                                }
                                else
                                        k++;
                        }
                        else
                        {
                                printf(" ");
                        }
                }
                printf("\n");
        }

blayt 发表于 2021-10-8 08:20:51

#include<bits/stdc++.h>

using namespace std;
int main()
{
        int n;
        while(~scanf("%d",&n))
        {
        int m=0,k=0;
      n=2*n-1;
      int i = 0,j=0;

      for (int i = 0; i < n; i++)
      {
                m=i;
                if (i>(n/2))
                {
                        m=(n-m-1);
                }
                k=0;
                for (int j = 0; j < n; j++)
                {
                        if ((j>=(n/2-m))&&(j<=(n/2+m)))
                        {
                              
                              printf("%c",'A'+k);
                              if (j>(n/2-1))
                              {
                                        k--;
                              }
                              else
                                        k++;
                        }
                        else
                        {
                              printf(" ");
                        }
                }
                printf("\n");
      }
    }
}

blayt 发表于 2021-10-8 08:21:26

加了个多组输入

傻眼貓咪 发表于 2021-10-8 16:31:36

Python 代码:n = int(input())

for i in range(n, 0, -1):
    alphabet = ''.join()+''.join()
    space = " "*(i-1)
    print(space + alphabet + space)

for i in range(2, n+1):
    alphabet = ''.join()+''.join()
    space = " "*(i-1)
    print(space + alphabet + space) C++ 代码:#include <bits/stdc++.h>
using namespace std;

int main(){
    int n;
    cin >> n;
    for(int i=n; i>0; i--){
      for(int j=0; j<i-1; j++) cout << " ";
      for(int j=65; j<(n-i+65); j++) cout << (char)j;
      for(int j=n-i+65; j>=65; j--) cout << (char)j;
      for(int j=0; j<i-1; j++) cout << " ";
      cout << endl;
    }
    for(int i=2; i<=n; i++){
      for(int j=0; j<i-1; j++) cout << " ";
      for(int j=65; j<(n-i+65); j++) cout << (char)j;
      for(int j=n-i+65; j>=65; j--) cout << (char)j;
      for(int j=0; j<i-1; j++) cout << " ";
      cout << endl;
    }
    return 0;
}C 代码:#include <stdio.h>

int main(){
    int n;
    scanf("%d", &n);
    for(int i=n; i>0; i--){
      for(int j=0; j<i-1; j++) printf(" ");
      for(int j=65; j<(n-i+65); j++) printf("%c", j);
      for(int j=n-i+65; j>=65; j--) printf("%c", j);
      for(int j=0; j<i-1; j++) printf(" ");
      printf("\n");
    }
    for(int i=2; i<=n; i++){
      for(int j=0; j<i-1; j++) printf(" ");
      for(int j=65; j<(n-i+65); j++) printf("%c", j);
      for(int j=n-i+65; j>=65; j--) printf("%c", j);
      for(int j=0; j<i-1; j++) printf(" ");
      printf("\n");
    }
    return 0;
}
页: [1]
查看完整版本: 菱形字母塔