用来练手的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] = 10 return a result = 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] = 10 return res result = test_2(m) print("result :"+ str(result)) print("m :"+ str(m))输出结果: