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 1412 {A} + {B}
{A} + {B} Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 19833    Accepted Submission(s): 8245 Problem Description 给你两个集合,要求{A} + {B}.
845 0
|
机器学习/深度学习 人工智能
HDU 2674
  题意:求N!mod2009,N=41时,N!因式分解一定含7*7*41,即N!%2009=0.所以只要计算0
721 0
|
人工智能
hdu2084数塔
经典问题了,题意我就不叙述了(题目是中文的~) 分析:dp[i][j]表示在第i行第j个位置上能取得的最大和,那么要从最后一行开始算起,到塔顶结束:dp[i][j] = a[i][j]+max(dp[i+1][j], dp[i+1][j+1]), 边界条件是dp[n][j] = a[n][j]; ...
673 0
hdu 4463 Outlets
点击打开链接hdu 4463 思路:最小生成树+kruskal 分析: 1 题目要求的找到n个商店组成n-1条边,并且要求耐克和苹果商店肯定要相连,求最短长度 2 很明显的最小生成树的模板题,由于要求耐克和苹果的商店要在一起那么就要把这两个商店编号合并到同一个集合,然后在利用kruskal计算。
914 0
|
存储
hdu 2203 亲和串
点击打开链接hdu 2203 思路:kmp 分析: 1 题目要求的是给定字符串s1 和 s2,问s1能否通过移位得到使得s2包含在s1里面。
823 0
|
人工智能 Java
HDU 4267
A Simple Problem with Integers Time Limit: 5000/1500 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 323 Accepted Submission(s): 133 Problem Description Let A1, A2, .
709 0

热门文章

最新文章