您好,登錄后才能下訂單哦!
本文小編為大家詳細介紹“c語言如何實現數組循環左移m位”,內容詳細,步驟清晰,細節處理妥當,希望這篇“c語言如何實現數組循環左移m位”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。
#include<stdio.h> //函數原型 void rightshiftleft(int *p_num,int n,int m); void enterint(int *p_num,int n); //主函數 void main(){ int num[100] = {1,2,3,4,5},*p_num = num; int n = 5,m = 2; printf("Int =:"); scanf("%d",&n); printf("M =:"); scanf("%d",&m); //整數輸入 enterint(p_num,n); //數組左移 rightshiftleft(p_num,n,m); for(int i = 0; i < n; i++){ printf("%-5d",p_num[i]); } } //整數輸入 void enterint(int *p_num,int n){ for(;n > 0 ; n--){ scanf("%d",p_num++); } } //循環數組左移算法 void rightshiftleft(int *p_num,int n,int m){ //臨時變量 int temp = 0; //外層循環控制需要左移的次數 for(int k = 0;k < m ; k++){ temp = p_num[n - m + k]; //內層循環控制n-m的數組元素整體右移一位 for(int i = 0; i < n - m ; i++){ p_num[n -m -i+ k] = p_num[n - m -1 -i +k]; } p_num[k] = temp; } }
本題要求實現一個對數組進行循環左移的簡單函數:一個數組a中存有n(>0)個整數,將每個整數循環向左移m(≥0)個位置,即將a中的數據由(a0a1…an-1)變換為(am…an-1a0a1…am-1)(最前面的m個數循環移至最后面的m個位置)。如果還需要考慮程序移動數據的次數盡量少,要如何設計移動的方法?
輸入第1行給出正整數n(≤100)和整數m(≥0);第2行給出n個整數,其間以空格分隔。
在一行中輸出循環左移m位以后的整數序列,之間用空格分隔,序列結尾不能有多余空格。
輸入樣例
8 3
1 2 3 4 5 6 7 8
輸出樣例
4 5 6 7 8 1 2 3
代碼如下:
#include<stdio.h> int main() { int n,m,i; scanf("%d%d",&n,&m);//獲取n和m的值 if(m>n) m=m%n;//去掉多余無意義的左移次數 int a[n]; for(i=n-m;i<n;i++)//先從左移后的位置開始存 scanf("%d",&a[i]); for(i=0;i<n-m;i++)//再從a[0]往后存 scanf("%d",&a[i]); for(i=0;i<n;i++)//輸出數組中的各個元素 { printf("%d",a[i]); if(i!=n-1)//這樣是為了讓結尾沒有空格 printf(" "); } return 0; }
然后說一下這題的思路,題目的要求其實就是將數組左移m位,然后輸出。
那么,我們其實可以先算出a[0]移動后的位置就是a[n-m](如輸入樣例中的8 3,左移三位后,a[0]元素的位置其實就移動到a[5]了),所以第一個for循環輸入的是a[m-n]到a[n-1]的值,然后第二個for循環再從a[0]接著輸入到a[m-n-1],最后再直接輸出整個數組即可。
關于m>n的情況:當m>n的時候,我們可以發現,其實要左移的位置就是m%n(如n=3,m=4,其實就只需要左移4%3=1次),因為3個數左移3位還是本身,所以我們只需要在前面加一個判斷,當m>n的時候,m=m%n就可以去掉多余無意義的左移。
讀到這里,這篇“c語言如何實現數組循環左移m位”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。