给出一个以零结尾的非零整数序列,按照从小到大的顺序。
输出每个数字的平方,从小到大的顺序。
只能用while循环,而且不能用内置函数(len()这个可以
比如输入:-12 -7 1 3 20
输出:1 9 49 144 400
该怎么把输出后的顺序排列啊,就是怎么把负数的平方按照顺序排到后面去
给出一个以零结尾的非零整数序列,按照从小到大的顺序。
输出每个数字的平方,从小到大的顺序。
只能用while循环,而且不能用内置函数(len()这个可以
比如输入:-12 -7 1 3 20
输出:1 9 49 144 400
该怎么把输出后的顺序排列啊,就是怎么把负数的平方按照顺序排到后面去
这个代码可以实现所有数列的排序,不限于题主所述要求
def pow2(x): # 计算平方函数
return x ** 2
nums = list(map(pow2, map(int, input('输入序列').split())))
# 获取未排序的平方数列表
while True:
flag = True # 每次遍历前将判断变量设置为真
for index in range(len(nums) - 1): # 遍历除最后一个元素外的数字索引
if nums[index] > nums[index + 1]: # 判断当前数字是否比后一位大
nums[index], nums[index + 1] = nums[index + 1], nums[index] # 大于则将二者交换
flag = False # 只要发生交换,就不能确保完全由小到大排序,判断变量为False
if flag: # 当整个遍历过程没有发生交换,说明完全排序,结束循环
break
print(nums)