本題要求你寫個程式把給定的符號列印成沙漏的形狀。例如給定17個「*」,要求按下列格式列印
*****
**** ***
*****
所謂「沙漏形狀」,是指每行輸出奇數個符號;各行符號中心對齊;相鄰兩行符號數差2;符號數先從大到小順序遞減到1,再從小到大順序遞增;首尾符號數相等。
給定任意n個符號,不一定能正好組成乙個沙漏。要求列印出的沙漏能用掉盡可能多的符號。
輸入在一行給出1個正整數n(≤1000)和乙個符號,中間以空格分隔。
首先列印出由給定符號組成的最大的沙漏形狀,最後在一行中輸出剩下沒用掉的符號數。
19 *
*****
**** ***
*****
2
計算一半沙漏包含的字元數量,利用等差公式計算行數和最長一行的字元數;
迴圈輸出。
注意沙漏每行末尾的空格不要列印,否則就會有格式錯誤!!
# -*- coding: utf-8 -*-
import math
"""created on mon jun 29 21:51:52 2020
@author: lenovo
"""sum = 0
def input():
n ,ch = map(str, input().split())
n = int(n)
return n,ch
def row(n, a, d):
half = (n+1)/2
row = int(math.sqrt(half))
a1 = a
a_ = a1 + (row - 1)*d
#print(row, a_)
return row, a_
def perrow(row, a1, d):
an = a1 + (row - 1)*d
#print(an)
global sum
sum += an
return an
def box(a_ , an):
box = (a_ - an)/2
return box
def print(num , cha):
for i in range(1,int(num+1)):
print(cha,end = "")
if __name__ == '__main__':
a1 = 1
d = 2
b = ' '
n, ch = input()
row, a_ = row(n, a1, d)
for j in range(int(row),1,-1):
an = perrow(j , a1, d)
box = box(a_, an)
print(box, b)
print(an, ch)
#print(box, b)
print("")
for i in range(1,int(row+1)):
an = perrow(i , a1, d)
box = box(a_, an)
print(box, b)
print(an, ch)
#print(box, b)
print("")
print(n-sum, end = "")
列印菱形 列印沙漏
輸入 輸出樣例輸入 5樣例輸出 提示 每行輸出最後乙個星號後面沒有空格 多組測試資料 include include 只需找出每一行和空格 之間的關係即可 intmain for z 1 z 2 i 1 z printf n for i n 1 i 1 i 行數後半段是前半段的顛倒 for z 2 ...
沙漏演算法列印
列印沙漏演算法計算題 include using namespace std int main else if number temp 2 a 2 while 1 經過確定之後的匹配最大的列印沙漏,列印的只是一部分的四分之一,並且將中間的位置在四分之一的計算過程,之後用a temp 1的方式反而將迴...
列印沙漏程式設計
本題要求你寫個程式把給定的符號列印成沙漏的形狀。例如給定17個 要求按下列格式列印 謂 沙漏形狀 是指每行輸出奇數個符號 各行符號中心對齊 相鄰兩行符號數差2 符號數先從大到小順序遞減到1,再從小到大順序遞增 首尾符號數相等。給定任意n個符號,不一定能正好組成乙個沙漏。要求列印出的沙漏能用掉盡可能多...