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


  • 相关阅读:
    二分题目
    求最小公倍数的最简模板
    用 vue 脚手架 vue-cli 初始化(新建)项目
    电脑没有声音
    node.js 安装步骤
    phpStrom编辑器 通过 git 提交代码到 gitlab
    jq 实现头像(气泡式浮动)
    微信网页授权 、获取用户昵称 头像等信息
    秒格式化 “秒” 为 天 时 分 秒
    改变swiper 按钮swiper-button-next 颜色
  • 原文地址:https://www.cnblogs.com/lcchuguo/p/4065858.html
Copyright © 2011-2022 走看看