【PAT甲级 U形打印】1031 Hello World for U (20 分) Java版 6/6通过
生活随笔
收集整理的這篇文章主要介紹了
【PAT甲级 U形打印】1031 Hello World for U (20 分) Java版 6/6通过
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
題目
一開始沒看懂“as squared as possible”和那個max不等式到底是什么意思,看了別人的解答才明白:
- 如果n % 3 == 0,n正好被3整除,直接n1 = n2 = n3
- 如果n % 3 == 1,因為n2要比n1大,所以把多出來的那1個給n2
- 如果n % 3 == 2,就把多出來的那2個給n2
題解
import java.util.Scanner;public class Main {public static void main(String[] args) {String str = new Scanner(System.in).nextLine();Spuare s = new Spuare(str);s.print();} }class Spuare {String str;int len;// 總長int n1;// 左int n2;// 下int n3;// 右// 如果n % 3 == 0,n正好被3整除,直接n1 = n2 = n3// 如果n % 3 == 1,因為n2要比n1大,所以把多出來的那1個給n2// 如果n % 3 == 2,就把多出來的那2個給n2public Spuare(String str) {this.str = str;this.len = str.length();int n = len + 2;if (n % 3 == 0) {n1 = n2 = n3 = n / 3;} else if (n % 3 == 1) {n1 = n3 = n / 3;n2 = n1 + 1;} else {n1 = n3 = n / 3;n2 = n1 + 2;}}// 打印public void printSpace() {for (int i = 0; i < n2 - 2; i++) {System.out.print(" ");}}public void print() {// 側邊for (int i = 0; i < n1 - 1; i++) {System.out.print(str.charAt(i));printSpace();System.out.println(str.charAt(len - 1 - i));}// 底邊for (int i = n1 - 1; i <= len - n1; i++) {System.out.print(str.charAt(i));}}}附:各種長度的排列情況,便于理解
o o oooo o ooooo o o o oooo o o o ooooo o o o oooooo o o o o o ooooo o o o o o oooooo o o o o o ooooooo o o o o o o o oooooo o o o o o o o ooooooo o o o o o o o ooooooo總結
以上是生活随笔為你收集整理的【PAT甲级 U形打印】1031 Hello World for U (20 分) Java版 6/6通过的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【PAT甲级 十进制转十三进制】1027
- 下一篇: 【CentOS7配置】如何设置:启动后自