用来练手的python练习题,原题链接: python练习实例68
题干: 有 n 个整数,使其前面各数顺序向后移 m 个位置,最后 m 个数变成最前面的 m 个数
代码如下:
import numpy as np
# 构造一个储存了n个整数的numpy数组
def numbers_input(n):a = np.zeros(n)for i in range(n):a[i] = int(input("输入一个整数:"))print(a)return a# 移动各个对应数字
def move_number(number_array, m):temp = np.zeros(m)result = np.copy(number_array)temp[:] = number_array[-m:]result[m:] = np.copy(number_array[:number_array.shape[0]-m])result[:m] = temp[:]return result
测试及输出结果如下:
这里我们又要注意在数组的复制,以及函数调用过程中的小问题,可以参考前文 赋值语句及复制数组相关。当我们使用一个全局数组作为函数的参数时,在函数内部对数组的操作,也会对全局数组本身造成改变。如果不想要改变一开始的全局数组而使用返回值,那么就需要在函数内部重新分配一块新的内存(使用np.zeros或者np.copy方法)。
相关测试代码如下:
m = np.array([1,2,3,4])
def test(a):a[3] = 10return aresult = test(m)
print("result :"+ str(result))
print("m :"+ str(m))
输出结果:
m = np.array([1,2,3,4])
def test_2(a):res = np.copy(a)res[3] = 10return resresult = test_2(m)
print("result :"+ str(result))
print("m :"+ str(m))
输出结果: