一篇辣鸡python写题目感想之——PTA自测-1 打印沙漏

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

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

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

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

输入格式:

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

输出格式:

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

输入样例:

19 *

输出样例:

*****
 ***
  *
 ***
*****
2


-----------------------------------------------------------我是华丽的分割线--------------------------------------------------------------------------
解题思路是什么?
我一看到这个题,诶呀简单。那不就是直接打印?
print(''' *****
***
*
***
***** ''')

完事了?
然后我仔细读题,发现是在下傻了,彻底傻了。
好吧,虽然以前做过打印一个金字塔类似的题目,但是给定个数并且打印沙漏这样的题目其实实现起来会难很多。
不过我还是把大致的思路通过python实现了出来,虽然这个代码其实是运行不了的,但是思路在这里你们看懂就好
(这也是为了防止某些喜欢剽窃的人)
复制代码
a=int(input())
b=input()
c=1
i=1
kong=0
while i<20:
   i+=1
   c=c+2*(1+2*i)       #多少个打印
   if b%c<2*(1+2*(i+1)):     #若不大于
     d=a-c
     break
for n in range(1,2*i-1):     #总共有这么多行
 if (2*i-1)-kong!=1          #当空格字符数量等于1
      for p in range(1,2*(1+2*i)):#总共要打印的是n行
        for i2 in range(0,kong):
          print(" ")                 #打印一个空字符
        for i1 in range(0,1+2*(i-1)-2*kong):
          print("*")                  #打印一个符号
   kong+=1
 else
      for p in range(1, 2 * (1 + 2 * i)):  # 总共要打印的是n行
          for i2 in range(0, kong):
              print(" ")  # 打印一个空字符
          for i1 in range(0, 1 + 2 * (i - 1) - 2 * kong):
              print("*")  # 打印一个符号
   kong-=1
 print("/")
print(d)
复制代码

这段代码其实是错的。再次声明
我知道我菜,所以大佬来喷我呀!

我真的很欠打.....好吧

posted on   大湿Mastwet  阅读(933)  评论(1编辑  收藏  举报

编辑推荐:
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
阅读排行:
· DeepSeek “源神”启动!「GitHub 热点速览」
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)
· DeepSeek R1 简明指南:架构、训练、本地部署及硬件要求
· 2 本地部署DeepSeek模型构建本地知识库+联网搜索详细步骤

导航

< 2025年2月 >
26 27 28 29 30 31 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 1
2 3 4 5 6 7 8
点击右上角即可分享
微信分享提示