• 第六届蓝桥杯试题c/c++B组4



    格子中输出

    StringInGrid函数会在一个指定大小的格子中打印指定的字符串。
    要求字符串在水平、垂直两个方向上都居中。
    如果字符串太长,就截断。
    如果不能恰好居中,可以稍稍偏左或者偏上一点。

    下面的程序实现这个逻辑,请填写划线部分缺少的代码。

    #include <stdio.h>
    #include <string.h>

    void StringInGrid(int width, int height, const char* s)
    {
    int i,k;
    char buf[1000];
    strcpy(buf, s);
    if(strlen(s)>width-2) buf[width-2]=0;

    printf("+");
    for(i=0;i<width-2;i++) printf("-");
    printf("+ ");

    for(k=1; k<(height-1)/2;k++){
    printf("|");
    for(i=0;i<width-2;i++) printf(" ");
    printf("| ");
    }

    printf("|");

    printf("%*s%s%*s",_____________________________________________); //填空

    printf("| ");

    for(k=(height-1)/2+1; k<height-1; k++){
    printf("|");
    for(i=0;i<width-2;i++) printf(" ");
    printf("| ");
    }

    printf("+");
    for(i=0;i<width-2;i++) printf("-");
    printf("+ ");
    }

    int main()
    {
    StringInGrid(20,6,"abcd1234");
    return 0;
    }

    对于题目中数据,应该输出:
    +------------------+
    | |
    | abcd1234 |
    | |
    | |
    +------------------+

    #include <stdio.h>
    #include <string.h>
    
    void StringInGrid(int width, int height, const char* s)
    {
        int i,k;
        char buf[1000];
        strcpy(buf, s);
        if(strlen(s)>width-2) buf[width-2]=0;
        
        printf("+");
        for(i=0;i<width-2;i++) printf("-");
        printf("+
    ");
        
        for(k=1; k<(height-1)/2;k++){
            printf("|");
            for(i=0;i<width-2;i++) printf(" ");
            printf("|
    ");
        }
        
        printf("|");
        
        printf("%*s%s%*s",((width-2-strlen(buf))/2)," ",buf,((width-2-strlen(buf))/2)," ");  
                  
        printf("|
    ");
        
        for(k=(height-1)/2+1; k<height-1; k++){
            printf("|");
            for(i=0;i<width-2;i++) printf(" ");
            printf("|
    ");
        }    
        
        printf("+");
        for(i=0;i<width-2;i++) printf("-");
        printf("+
    ");    
    }
    
    int main()
    {
        StringInGrid(20,6,"abcd1234");
        return 0;
    }
  • 相关阅读:
    音频、视频等文件格式(.ts、.meta)及其认识
    元素之和最接近 0 的区间(部分和)
    元素之和最接近 0 的区间(部分和)
    说话的智慧
    说话的智慧
    工业相机基本参数以及选型参考(二)
    常用编程软件站点、镜像站、科技类 PDF
    常用编程软件站点、镜像站、科技类 PDF
    经典书单 —— 语言/算法/机器学习/深度学习/AI/CV/PGM
    hdu1024 Max Sum Plus Plus
  • 原文地址:https://www.cnblogs.com/a863886199/p/6568193.html
Copyright © 2020-2023  润新知