PAT甲级1031 Hello World for U (20分)|C++实现

一、题目描述

原题链接
在这里插入图片描述

Input Specification:

Each input file contains one test case. Each case contains one string with no less than 5 and no more than 80 characters in a line. The string contains no white space.

​​Output Specification:

For each test case, print the input string in the shape of U as specified in the description.

Sample Input:

helloworld!

Sample Output:

在这里插入图片描述

二、解题思路

其实我认为在20分题中,这个题目还是有点复杂的。题目已经告诉了我们数量关系,第一列和第三列字符个数为 n 1 , n 3 n_1, n_3 n1,n3,最底下一行的字符数为 n 2 n_2 n2。根据样例我们可以看出, n 1 = n 3 n_1 = n_3 n1=n3,那么 n 1 n_1 n1可以表示为 n 1 = ( N − n 2 + 2 ) / 2 n_1 = (N - n_2 + 2)/2 n1=(Nn2+2)/2。所以我们可以从3开始遍历选取 n 2 n_2 n2,找到的 n 2 n_2 n2必须满足两个条件,一个是 ( N − n 2 + 2 ) (N-n_2+2) (Nn2+2)必须是偶数,还有一个就是 n 1 ≤ n 2 n_1 \leq n_2 n1n2。满足这两个条件的数中,我们要取最大的 n 1 n_1 n1。这里要注意一个小小的坑,就是每一次循环, n 1 n_1 n1都要初始化为一个很小的数,否则上一个循环的不符合条件的 n 1 n_1 n1就会沿用到这里,造成错误。

三、AC代码

#include<iostream>
#include<string>
#include<algorithm>
#include<cstdio>
using namespace std;
const int maxn = 85;
int main()
{
  char order[maxn][maxn];
  fill(order[0], order[0]+maxn*maxn, ' ');
  string str;
  cin >> str;
  int sze = str.size();
  int n1, n2, cnt=0, maxk=0;
  for(n2 = 3; n2<sze; n2++)
  {
    n1 = -1;//测试点5
    if((sze+2-n2)%2 == 0)
    	n1 = (sze+2-n2)/2;
    if(n1>maxk && n1<=n2)	maxk = n1;
  }
  n1 = maxk;
  n2 = sze+2-2*n1;
  for(int i=0; i<n1-1; i++)
    order[i][0] = str[cnt++];
  for(int i=0; i<n2; i++)
    order[n1-1][i] = str[cnt++];
  for(int i=n1-2; i>=0; i--)
    order[i][n2-1] = str[cnt++];
  for(int i=0; i<n1; i++)
  {
    for(int j=0; j<n2; j++)
      printf("%c", order[i][j]);
    printf("\n");
  }
  return 0;
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
经导师精心指导并认可、获 98 的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值