1. 输入一个正整数 n,并输出一个菱形,这个菱形有 2n−1 行,第一行有 1 个字母 A,之后的 n−1 行每行字母会变成上一行的下一个(A 的下一个是 B),且数量会递增 2 个,后面的 n+1 行至 2n−1 行,会变成上一行的上一个(B 的上一个是 A),且数量会递减 2 个,同时,我们需要在每行前输出一定数量的空格,以保证菱形居中,注意末尾不要有多余的输出。
样例输入
2
样例输出
A
BBB
A
样例输入2
3
样例输出2
A
BBB
CCCCC
BBB
A
思路:
分为上下两部分,先打印上部分,再打印下部分;
注意:最外边的循环控制内层的两个循环;
#include <stdio.h>
int main() {
int n;
scanf("%d", &n);
for(int i = 1; i <= n; i++) {
for (int j = 0; j < n - i; j++) {
printf(" ");
}
for (int j = 0; j < 2 * i - 1; j++) {
printf("%c", (char)('A' + i - 1));
}
printf("\n");
}
for (int i = n - 1; i > 0; i--) {
for (int j = 0; j < n - i; j++) {
printf(" ");
}
for (int j = 0; j < 2 * i - 1; j++) {
printf("%c", (char)('A' + i - 1)); // 强转
}
printf("\n");
}
return 0;
}
2.题目描述
参照样例按要求输出字母三角形。
输入
输入一个正整数 n。(0<n<7)
输出
按照样例输出。
样例输入
4
样例输出
ABCD
EFG
HI
J
#include<stdio.h>
int main() {
int n;
scanf("%d", &n);
char ch = 'A';
while(n) {
if(n < 7) {
for(int i = 1; i <= n; i++) {
printf("%c",ch);
ch++;
}
printf("\n");
n--;
}
else printf("erro\n");
}
return 0;
}
题目描述
输入一个正整数 n,并输出一个三角形,这个三角形有 n 行,第一行有 2n 个字母 A,之后每行字母 A 的数量会递减 2 个。
输入
输入一个正整数 n。(0<n<40)
输出
按照样例输出。
样例输入
2
样例输出
AAAA
AA
样例输入2
3
样例输出2
AAAAAA
AAAA
AA
#include<stdio.h>
void tra(int n) {
for(int i = n; i > 0; i--) {
for(int j = 1; j <= 2 * i; j++) {
printf("A");
}
printf("\n");
}
return ;
}
int main() {
int n;
scanf("%d", &n);
tra(n);
return 0;
}
题目描述
输入一个正整数 n,并输出一个菱形,这个菱形有 2n−1 行,第一行有 2 个字母 A,之后的 n−1 行每行字母 A 的数量会递增 2 个,后面的 n+1 行至 2n−1 行,每行字母 A 的数量会递减 2 个,同时,我们需要在每行前输出一定数量的空格,以保证菱形居中,注意末尾不要有多余的输出。
输入
输入一个正整数 n。(0<n<40)
输出
按照样例输出。
样例输入
2
样例输出
AA
AAAA
AA
样例输入2
3
样例输出2
AA
AAAA
AAAAAA
AAAA
AA
#include<stdio.h>
void tra(int n) {
for(int i = 1; i <= n; i++) {
for(int j = 1; j < n + 1 - i; j++) {
printf(" ");
}
for(int m = 1; m <= i; m++){
printf("AA");
}
printf("\n");
}
for(int i = 0; i < n - 1; i++){
for(int j = 1; j <= i + 1; j++){
printf(" ");
}
for(int m = 1; m <= n - 1 - i ; m++) {
printf("AA");
}
printf("\n");
}
}
int main() {
int n;
scanf("%d", &n);
tra(n);
return 0;
}
题目描述
输入一个正整数 n,并输出一个沙漏形,这个沙漏形有 2n+1 行,第一行有 2n+1 个字母,其中前 n+1 个字符是从 A 开始依次递增的,而后 n 个字符是由第 n+1 个字符开始依次递减的。之后的 n 行每行会少头尾两个字母。再之后的 n 行则正好是前 n 行反过来输出的结果。注意末尾不要有多余的输出。
输入
输入一个正整数 n。(0<n<26)
输出
按照样例输出。
样例输入
2
样例输出
ABCBA
BCB
C
BCB
ABCBA
样例输入2
3
样例输出2
ABCDCBA
BCDCB // 左右部分
CDC
D // 上下部分
CDC
BCDCB
ABCDCBA // 左右
思路:
这个是分四步打印的
#include <stdio.h>
int main() {
int n;
scanf("%d", &n);
for (int i = 0; i <= n; i++) {
for (int j = 0; j < i; j++) {
printf(" ");
}
for (int j = i; j <= n; j++) {
printf("%c", (char)('A' + j));
}
for (int j = n - 1; j >= i; j--) {
printf("%c", (char)('A' + j));
}
printf("\n");
}
for (int i = n - 1; i >= 0; i--) {
for (int j = 0; j < i; j++) {
printf(" ");
}
for (int j = i; j <= n; j++) {
printf("%c", (char)('A' + j));
}
for (int j = n - 1; j >= i; j--) {
printf("%c", (char)('A' + j));
}
printf("\n");
}
return 0;
}