zoukankan      html  css  js  c++  java
  • HDUJ 2074 叠筐 模拟

    叠筐

    Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
    Total Submission(s): 12017    Accepted Submission(s): 3074


    Problem Description
    须要的时候,就把一个个大小差一圈的筐叠上去,使得从上往下看时,边筐花色交错。这个工作如今要让计算机来完毕,得看你的了。
     

    Input
    输入是一个个的三元组,各自是,外筐尺寸n(n为满足0<n<80的奇整数),中心花色字符,外筐花色字符,后二者都为ASCII可见字符;
     

    Output
    输出叠在一起的筐图案,中心花色与外筐花色字符从内层起交错相叠,多筐相叠时,最外筐的角总是被打磨掉。叠筐与叠筐之间应有一行间隔。
     

    Sample Input
    11 B A 5 @ W
     

    Sample Output
    AAAAAAAAA ABBBBBBBBBA ABAAAAAAABA ABABBBBBABA ABABAAABABA ABABABABABA ABABAAABABA ABABBBBBABA ABAAAAAAABA ABBBBBBBBBA AAAAAAAAA @@@ @WWW@ @W@W@ @WWW@ @@@
     



    #include<iostream>
    #include<cstring>
    using namespace std;
    
    int main()
    {
    	int n;
    	char c1,c2,k=0;
    	while(cin>>n)
    	{
    		cin>>c1>>c2;
    		int i,j,m,p,q;
    		char str[81][81];
    		memset(str,0,sizeof(str));
    		p=0;q=n-1;m=(n-1)/2;
    		if(k++)   cout<<endl;
    
    		if(n==1)
    			cout<<c1<<endl;
    		else
    		{
    			while(m<=q)
    			{
    				if((q-p+1)%4==3)
    				{
    					for(i=p;i<=q;i++)
    						for(j=p;j<=q;j++)
    							str[i][j]=c2;
    					p++;q--;
    				}
    				else
    				{
    					for(i=p;i<=q;i++)
    						for(j=p;j<=q;j++)
    							str[i][j]=c1;
    					p++;q--;
    				}
    			}
    
    			str[0][0]=str[n-1][0]=str[0][n-1]=str[n-1][n-1]=' ';
    			for(i=0;i<n;i++)
    				cout<<str[i]<<endl;
    		}
    	}
    
    	return 0;
    }


  • 相关阅读:
    CF Round #427 (Div. 2) C. Star sky [dp]
    顺时针打印矩阵
    堆 栈-相关知识【转】
    二叉树的镜像
    树的子结构
    合并两个排序的链表
    数值的整数次方
    位运算:二进制中1的个数
    斐波那契数列及其变形
    重建二叉树
  • 原文地址:https://www.cnblogs.com/lcchuguo/p/4065858.html
Copyright © 2011-2022 走看看