菱形字母塔
本帖最后由 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 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");
} #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");
}
}
} 加了个多组输入 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]