天天看點

循環左移&循環右移

上次C語言沒做出來的題目---将數組a[]循環左移k位,輸出移位後的數組,例如a[]={1,2,3,4,5}左移一位,輸出為:2 3 4 5 1。

------------------------------------------------------------------------- 循環左移 -------------------------------------------------------------------------

#include<stdio.h>
#define k 1  //循環左移的位數 
#define n 6  //數組長度 
int main(void)
{
	int a[n]={1,2,3,4,5,6}; //數組長度n 
	int i,j,temp;
	for(i=0;i<k;i++)     //外循環 控制内循環次數以及最低位到最高位的移位  
	{
		temp=a[0];	//最低位被更新之前存到變量temp中	 
		
		for(j=0;j<n-1;j++)  //内循環 從次低位開始 依次将數向低位移動一位
			a[j]=a[1+j];   
				
		a[n-1]=temp;  //更新最高位   
	}		
	for(i=0;i<n;i++)
		printf("%d ",a[i]);
	printf("\n");
}
           

-------------------------------------------------------------------------流程圖-------------------------------------------------------------------------

循環左移&amp;循環右移

------------------------------------------------------------------------- 循環右移 -------------------------------------------------------------------------

/*将長度為n的數組a循環右移k個元素*/ 
#include<stdio.h> 
#define k 2  //右移位數 
#define n 6  //數組長度 
int main(void)
{
	int a[n]={1,2,3,4,5,6};
	int i,j,temp;
	for(i=0;i<k;i++) //要右移k次 
	{
		temp=a[n-1];	//将最高位(n-1)數字存到變量temp中 
		
		for(j=n-1;j>0;j--) //從次高位(n-2)開始 依次向高位移動一位 
			a[j]=a[j-1];
			
		a[0]=temp;  //更新最低位 
	}
	for(i=0;i<n;i++)	//循環列印數組中這n個數 
		printf("%2d",a[i]);	
	printf("\n");	
}
           

-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

編輯這篇花了好久,不是想題目,主要是用部落格不久,很多功能都不太熟悉。加上xind也不是特别會用(流程圖畫的特蹩腳,望大神幫忙)。這一來二去耽誤了好久。

我希望開個練習版塊把自己平時學C語言遇到的問題記錄下來,一方面是為了使自己“溫故而知新”,另一方面也希望跟部落格裡的大神交流,向大家學習。

繼續閱讀