zoukankan      html  css  js  c++  java
  • PAT天梯赛L1-002 打印漏斗

    题目链接:点击打开链接

    本题要求你写个程序把给定的符号打印成沙漏的形状。例如给定17个“*”,要求按下列格式打印

    *****
     ***
      *
     ***
    *****
    

    所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。

    给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。

    输入格式:

    输入在一行给出1个正整数N(<=1000)和一个符号,中间以空格分隔。

    输出格式:

    首先打印出由给定符号组成的最大的沙漏形状,最后在一行中输出剩下没用掉的符号数。

    输入样例:
    19 *
    
    输出样例:
    ***** *** * ********2
    思路:这道题好像是新生赛的后几道。。。一直感觉图案题特别难,耗时。
    就是单纯的找规律。还有就是把n取小,图案分几部分输出。
    AC代码:
    #include<iostream>
    using namespace std;
    int main() {
    	int n;                   //*** 
    	char c;                  // *
    	cin >> n >> c; //i为行号 //*** 
    	int i = 2, ans = 1, sum = 0; //看右边图案, 由于只有1个单独的,所以i从2开始 
    	while(1) {//这个结构得到要输入几行 
    		if(n > ans + (2 * i - 1) * 2) {
    			ans = ans + (2 *i - 1) * 2; 
    			++i;
    		} else break; 
    	}//由于i++, 所以要-1 
    	for(int j = i-1; j > 0; j--) { 
    		for(int z = 0; z < i - j - 1; z++) {//这个纯属看 乱写
    			cout << " "; 
    		}
    		if(j != 1) {//特别判断 
    			for(int k = 0; k < 2 * j - 1; k++) {
    				cout << c;
    				sum++; 
    			}
    			cout << endl;
    		}else {
    			cout << c << endl;
    			sum++; 
    		}
    	}//输出下半部分
    	for(int j = 2; j <= i - 1; j++) {
    		for(int z = 0; z < i - 1 - j; z++) {
    			cout << " ";
    		} 
    		for(int k = 0; k < 2 * j - 1; k++) {
    			cout << c;
    			sum++;
    		} 
    		cout << endl; 
    	} 
    	cout << n - sum;
    	return 0;
    } 
     

    
    

  • 相关阅读:
    [软件逆向]实战Mac系统下的软件分析+Mac QQ和微信的防撤回
    测试Storm的多源头锚定
    理解Storm可靠性消息
    Storm处理流程, 基本参数配置
    解决Storm 和yarn 8080 端口冲突
    TridentState分析
    Trident中 FixedBatchSpout分析
    Java序列简单使用
    JVM 监控以及内存分析
    Zookeeper入门开发demo
  • 原文地址:https://www.cnblogs.com/ACMerszl/p/9573000.html
Copyright © 2011-2022 走看看