图形集合--C语言

​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;
}
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值