C語言數(shù)組元素循環(huán)右移問題及解決方法
C 語言是一種通用的、面向過程式的計算機(jī)程序設(shè)計語言。1972 年,為了移植與開發(fā) UNIX 操作系統(tǒng),丹尼斯·里奇在貝爾電話實(shí)驗室設(shè)計開發(fā)了 C 語言。
C 語言是一種廣泛使用的計算機(jī)語言,它與 Java 編程語言一樣普及,二者在現(xiàn)代軟件程序員之間都得到廣泛使用。
題目內(nèi)容:
解題思路
方法一:
這是我自己摸索出來的一種方法,通過對數(shù)組的多次逆置來達(dá)到循環(huán)的效果,一共對數(shù)組進(jìn)行了三次逆置,所以就需要構(gòu)造一個函數(shù),
這個函數(shù)既可以逆置一個數(shù)組,也可以逆置數(shù)組的部分區(qū)間。
1,先將整個數(shù)組[0,N)逆置一遍;
2,將數(shù)組的前部分區(qū)間[0,M)進(jìn)行逆置;
3,將數(shù)組的后部分區(qū)間[M,N)進(jìn)行逆置;
假設(shè)N=2,M=2,具體數(shù)組為nums[6]={1,2,3,4,5,6};則逆置過程如下圖所示:
代碼如下:
#include<stdio.h> void printArray(int nums[],int len); void reverseArrayPro(int nums[],int begin,int end); int main() { int len,move; int i = 0; scanf("%d%d",&len,&move); int nums[len]; for(i = 0;i < len;i++){ scanf("%d",&nums[i]); } move = move%len; reverseArrayPro(nums,0,len); reverseArrayPro(nums,0,move); reverseArrayPro(nums,move,len); printArray(nums,len); return 0; } //數(shù)組打印 void printArray(int nums[],int len){ int i=0; for(i = 0; i < len; i++){ if(i==len-1) printf("%d",nums[i]); else printf("%d ",nums[i]); } } //改進(jìn)版數(shù)組就地逆置 void reverseArrayPro(int nums[],int begin,int end){ int i=0; int j=1; for(i=begin;i<(end-begin)/2+begin;i++){ int temp = nums[i]; nums[i]=nums[end-j]; nums[end-j]=temp; j++; } }
方法二:
這是我在網(wǎng)上看的一種方法,這種方法跟我的方法比我的方法簡單許多,實(shí)際上它沒有移動數(shù)組中的元素,而只是簡單地改變了一下數(shù)組中元素的遍歷
順序,先遍歷出數(shù)組中 N-M ~ N-1號元素,再遍歷出0~N-M-1號元素。
代碼如下:
#include<stdio.h> int main() { int len,move; int i = 0; scanf("%d%d",&len,&move); int nums[len]; for(i = 0;i < len;i++){ scanf("%d",&nums[i]); } move = move%len; for(i = len-move;i<len;i++){ printf("%d ",nums[i]); } for(i = 0;i<len-move;i++){ if(i==len-move-1) printf("%d",nums[i]); else printf("%d ",nums[i]); } return 0; }
總結(jié)
到此這篇關(guān)于C語言數(shù)組元素循環(huán)右移問題及解決方法的文章就介紹到這了,更多相關(guān)C語言數(shù)組元素循環(huán)右移問題內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++實(shí)現(xiàn)單鏈表刪除倒數(shù)第k個節(jié)點(diǎn)的方法
這篇文章主要介紹了C++實(shí)現(xiàn)單鏈表刪除倒數(shù)第k個節(jié)點(diǎn)的方法,結(jié)合實(shí)例形式分析了C++單鏈表的定義、遍歷及刪除相關(guān)操作技巧,需要的朋友可以參考下2017-05-05Qt自定義控件實(shí)現(xiàn)圓盤進(jìn)度條
這篇文章主要為大家詳細(xì)介紹了Qt自定義控件實(shí)現(xiàn)圓盤進(jìn)度條,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-12-12C++ COM編程之QueryInterface函數(shù)(一)
這篇文章主要介紹了C++ COM編程之QueryInterface函數(shù)(一),QueryInterface是組件本身提供對自己查詢的一個接口,需要的朋友可以參考下2014-10-10C語言使用strcmp()函數(shù)比較兩個字符串的實(shí)現(xiàn)
這篇文章主要介紹了C語言使用strcmp()函數(shù)比較兩個字符串的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01解決gcc編譯報錯unknown type name ‘bool‘問題
這篇文章主要介紹了解決gcc編譯報錯unknown type name ‘bool‘問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-07-07mac 配置Clion運(yùn)行C和C++的環(huán)境的詳細(xì)步驟
這篇文章主要介紹了mac 配置Clion運(yùn)行C和C++的環(huán)境的步驟詳解,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-04-04C語言實(shí)現(xiàn)BMP圖像處理(直方圖均衡化)
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)BMP圖像直方圖均衡化處理,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-10-10