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;
}


相关文章
|
2月前
|
Java 测试技术
hdu 1228 A + B
hdu 1228 A + B
18 0
|
人工智能 Java 安全
HDU 1039 Easier Done Than Said?
Easier Done Than Said? Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 12751    Accepted Subm...
780 0
|
测试技术 Java
|
存储
hdu 2795 Billboard
点击打开hdu 2795 思路: 线段树+单点更新 分析: 1 题目的意思是给定一个h*w的广告牌h为高,w为宽,现在有n个高为1宽为wi的小广告要放上去,原则是最先放最上面和最左边的位置 2 题目的h和w的最大值为10^9,但是n最大为200000。
746 0
|
算法
hdu 2923 Einbahnstrasse
点击打开链接hdu 2923 思路:最短路+SPFA / 最短路+floyd 分析: 1 题目要求的是有n个点,然后有c个破车,这个c个破车可能在同一城市里面,现在要把这些破车统一拉到中心点1. 2 这题的中心在1点,那么所求 ans = 1->所有破车的距离之和 + 所有破车->1的之和。
700 0