HDU 1256 画8

简介:

画8

Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other)
Total Submission(s) : 2   Accepted Submission(s) : 2
Problem Description
谁画8画的好,画的快,今后就发的快,学业发达,事业发达,祝大家发,发,发.
 

Input
输入的第一行为一个整数N,表示后面有N组数据. 每组数据中有一个字符和一个整数,字符表示画笔,整数(>=5)表示高度.
 

Output
画横线总是一个字符粗,竖线随着总高度每增长6而增加1个字符宽.当总高度从5增加到6时,其竖线宽度从1增长到2.下圈高度不小于上圈高度,但应尽量接近上圈高度,且下圈的内径呈正方形. 每画一个"8"应空一行,但最前和最后都无空行.
 

Sample Input
 
 
2 A 7 B 8
 

Sample Output
 
 
AA AA AA AA AA AA AA AA AA AA AA BBB BB BB BB BB BBB BB BB BB BB BB BB BBB
 

Source
浙江工业大学第四届大学生程序设计竞赛
#include<stdio.h>
int F(int n)
{
    if(n==7)
        return 5;
    else
        return 5+(n-7)/2;

}
int main()
{
    int i,j,n,num,k,x1,x2,l,q=5,p,u1,u2;
    char str;
    scanf("%d",&n);
    while(n--)
    {
        p=2;
        scanf("\n%c %d",&str,&num);
        p=p+(num-6)/6;
        q=F(num);
        j=num-q;
        k=(num-3)/2;
        if((num-3)%2==0)
        {
            x1=k;x2=k;
        }
        else
        if((num-3)%2!=0)
        {
            x1=k;x2=k+1;
        }
        if(num!=6&&num!=5)
        {
            for(u1=0;u1<p;u1++)
            printf(" ");
            for(i=0;i<j;i++)
                printf("%c",str);
            puts("");
            for(i=0;i<x1;i++)
            {
                for(u1=0;u1<p;u1++)
                printf("%c",str,str);
                for(l=0;l<j;l++)
                printf(" ");
                for(u2=0;u2<p;u2++)
                printf("%c",str,str);
                puts("");
            }
            for(u1=0;u1<p;u1++)
            printf(" ");
            for(i=0;i<j;i++)
                printf("%c",str);
            puts("");;
            for(i=0;i<x2;i++)
            {
                for(u1=0;u1<p;u1++)
                printf("%c",str,str);
                for(l=0;l<j;l++)
                printf(" ");
                for(u2=0;u2<p;u2++)
                printf("%c",str,str);
                puts("");
            }
            for(u1=0;u1<p;u1++)
            printf(" ");
            for(i=0;i<j;i++)
                printf("%c",str);
            puts("");
        }
        else
        if(num==6)
        {
           printf("  ");
            for(i=0;i<2;i++)
                printf("%c",str);
            puts("");
            for(i=0;i<1;i++)
            {
                printf("%c%c",str,str);
                for(l=0;l<2;l++)
                printf(" ");
                printf("%c%c",str,str);
                puts("");
            }
            printf("  ");
            for(i=0;i<2;i++)
                printf("%c",str);
            puts("");;
            for(i=0;i<2;i++)
            {
                printf("%c%c",str,str);
                for(l=0;l<2;l++)
                printf(" ");
                printf("%c%c",str,str);
                puts("");
            }
            printf("  ");
            for(i=0;i<2;i++)
                printf("%c",str);
            puts("");
        }
        else
        if(num==5)
        {
           printf(" ");
            for(i=0;i<1;i++)
                printf("%c",str);
            puts("");
            for(i=0;i<1;i++)
            {
                printf("%c",str,str);
                for(l=0;l<1;l++)
                printf(" ");
                printf("%c",str,str);
                puts("");
            }
            printf(" ");
            for(i=0;i<1;i++)
                printf("%c",str);
            puts("");;
            for(i=0;i<1;i++)
            {
                printf("%c",str,str);
                for(l=0;l<1;l++)
                printf(" ");
                printf("%c",str,str);
                puts("");
            }
            printf(" ");
            for(i=0;i<1;i++)
                printf("%c",str);
            puts("");
        }
        if(n)
        puts("");
    }
    return 0;
}


相关文章
|
Java BI
HDU 2034 人见人爱A-B
人见人爱A-B Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 77157    Accepted Submission(s): 21509 Problem Description 参加过上个月月赛的同学一定还记得其中的一个最简单的题目,就是{A}+{B},那个题目求的是两个集合的并集,今天我们这个A-B求的是两个集合的差,就是做集合的减法运算。
1121 0
|
定位技术
hdu 4771 Stealing Harry Potter's Precious
点击打开链接 题意:题目给定一个n*m的地图,地图有一个起点标记为'@',还有'#'表示不能够走的,'.'表示可以走。给定k个点,问从起点开始把这k个点走过去的最小步数。
769 0
|
Java
HDU 1846(巴什博弈)
Brave Game Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 4050    Accepted Submission(s): 2644 Problem Description 十年前读大学的时候,中国每年都要从国外引进一些电影大片,其中有一部电影就叫《勇敢者的游戏》(英文名称:Zathura),一直到现在,我依然对于电影中的部分电脑特技印象深刻。
770 0
|
机器学习/深度学习 人工智能
HDU 2674
  题意:求N!mod2009,N=41时,N!因式分解一定含7*7*41,即N!%2009=0.所以只要计算0
692 0