数组元素前移后移 RUNOOB python练习题 68
生活随笔
收集整理的這篇文章主要介紹了
数组元素前移后移 RUNOOB python练习题 68
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
用來練手的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))輸出結果:
輸出結果:
總結
以上是生活随笔為你收集整理的数组元素前移后移 RUNOOB python练习题 68的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: RUNOOB python 67 数组的
- 下一篇: 如何使用python导入mat格式的数据