PTA刷题记录(1)
2019-11-07 16:03:08来源:博客园 阅读 ()
PTA刷题记录(1)
团队天梯赛-------(2)分值:20
题目要求:你写个程序把给定的符号打印成沙漏的形状。例如给定17个“*”,要求按下列格式打印
*****
***
*
***
*****
所谓“沙漏形状”,是指每行输出奇数个符号;各行符号中心对齐;相邻两行符号数差2;符号数先从大到小顺序递减到1,再从小到大顺序递增;首尾符号数相等。
给定任意N个符号,不一定能正好组成一个沙漏。要求打印出的沙漏能用掉尽可能多的符号。
解题思路:运用分治思想将此沙漏看做上下两部分,合理利用循环对此提进行解答。
代码如下;
import java.util.*;
public class pta_2 {
public static void pic(int q,String w) {
final int SIZE = 1000;
int[] a = new int[SIZE];
int[] b = new int[SIZE];
int i = 0,j = 1,k = 0;
int temp = 0,l = 0,temp1 = 0,temp2 = 1,temp3 = 0;
int n = 0,f = 0;
for(i = 0;i<SIZE; i++) {
a[i] = j;
j+=2;
}
b[0] = 1;
for(i = 1;i<SIZE; i++) {
b[i] = b[i-1] + 2 * a[i];
}
for(i = 0; i < SIZE;i++) {
if(q > b[i] && q < b[i+1]) {
temp2 = i;
break;
}
else if(q == b[i]) {
temp2 = i;
break;
}
}
temp = a[temp2];
temp1 = temp;
for(i = 0; i < temp; i++) {
if(i < temp / 2){
for(k = 0; k < (temp - temp1) / 2;k++) {
System.out.printf("%1s"," ");
}
for(l = 0; l < temp1;l++) {
System.out.print(w);
}
temp1-=2;
System.out.println();
}
else{
for(f = 0; f < ((temp - temp1) / 2);f++) {
System.out.printf("%1s"," ");
}
for(n = 0;n < temp1;n++) {
System.out.print(w);
}
temp1+=2;
System.out.println();
}
}
System.out.print(q - b[temp2]);
}
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner input = new Scanner(System.in);
int count = input.nextInt();
String fuhao = input.next();
pic(count,fuhao);
input.close();
}
}
原文链接:https://www.cnblogs.com/zrx-1022/p/11813890.html
如有疑问请与原作者联系
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- 大专毕业的00后,却可以在深圳拿到25k的薪资,只有不断的刷 2020-05-29
- JAVA 每次从List中取出100条记录 2020-05-27
- 初识JAVA(学习记录) 2020-05-19
- 错题记录——关于Java中private的用法(类与封装) 2020-05-16
- 坚持学习,坚持写博客,记录学习的点点滴滴,先从学习JAVA开 2020-05-16
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash