用來練手的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))
輸出結果: