C語言輪轉(zhuǎn)數(shù)組的三種實現(xiàn)
題目:

解法1:把最后一位數(shù)字移動到數(shù)組的第一位,然后將第二位開始的每一位往前移動一位
這種方法的時間復(fù)雜度=O(N^2)
空間復(fù)雜度=O(1)
rotate(int* arr, int n, int k)
{
k %= n;
int i = 0;
for (i = 0; i < k; i++)//旋轉(zhuǎn)k次
{
int tmp = arr[n - 1];//把最后一個數(shù)拿出來賦給tmp
//剩余元素整體向后移動
int j = 0;
for (j = n - 1; j > 0; j--)
{
arr[j] = arr[j - 1];
}
arr[0] = tmp;//把最后一個值賦給數(shù)組的首元素處
}
int a = 0;
for (a = 0; a < n; a++)
{
printf("%d", arr[a]);
}
}
int main()
{
int arr[10] = { 0,1,2,3,4,5,6,7,8,9 };
int n = sizeof(arr) / sizeof(arr[0]);
int k = 0;
scanf("%d", &k);
rotate(arr, n, k);
return 0;
}解法2:重新創(chuàng)建一個數(shù)組,把需要旋轉(zhuǎn)的拿幾個數(shù)字放在數(shù)組中,然后再把剩余的數(shù)放到這個新數(shù)組的后面
這種方法的時間復(fù)雜度=O(N)
空間復(fù)雜度=O(N)
void rotate(int* nums, int numsSize, int k)
{
int* tmp = (int*)malloc(sizeof(int) * numsSize);//開辟大小為n的動態(tài)內(nèi)存
k = k % numsSize;
memcpy(tmp, nums + numsSize - k, sizeof(int) * k);//把旋轉(zhuǎn)的數(shù)拷貝到新數(shù)組中
memcpy(tmp+k, nums, sizeof(int) * (numsSize-k));//剩下的數(shù)拷貝到新數(shù)組的后面
memcpy( nums,tmp, sizeof(int) * numsSize);//把新數(shù)組拷貝給原來的數(shù)組
free(tmp);
}解法3:原地解決(三旋法)——最優(yōu)法
這種方法的時間復(fù)雜度=O(N)
空間復(fù)雜度=O(1)

void reve(int arr[], int left, int right)//逆置函數(shù),三個逆置都適用
{
while (left < right)
{
int tmp = arr[left];
arr[left] = arr[right];
arr[right] = tmp;
left++;
right--;
}
}
rotate(int* arr, int n, int k)
{
k %= n;
reve(arr, n - k, n - 1);//逆置后面的數(shù)
reve(arr, 0, n - k - 1);//逆置前面的數(shù)
reve(arr, 0, n - 1);//整體逆置
int i = 0;
for (i = 0; i < n; i++)
{
printf("%d ", arr[i]);
}
}
int main()
{
int arr[10] = { 0,1,2,3,4,5,6,7,8,9 };
int n = sizeof(arr) / sizeof(arr[0]);
int k = 0;
scanf("%d", &k);
rotate(arr, n, k);
return 0;
}到此這篇關(guān)于C語言輪轉(zhuǎn)數(shù)組的三種實現(xiàn)的文章就介紹到這了,更多相關(guān)C語言輪轉(zhuǎn)數(shù)組內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
結(jié)構(gòu)體對齊的規(guī)則詳解及C++代碼驗證
在c語言的結(jié)構(gòu)體里面一般會按照某種規(guī)則去進行字節(jié)對齊。本文就來介紹一下如何實現(xiàn),具有一定的參考價值,感興趣的可以了解下2021-08-08
C語言編程銀行ATM存取款系統(tǒng)實現(xiàn)源碼
這篇文章主要為大家介紹了C語言編程銀行ATM存取款系統(tǒng)實現(xiàn)的源碼示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步2021-11-11
使用C++和Direct3D (d3d)獲取屏幕截圖并根據(jù)傳入分辨率進行縮放圖片大小(最新推薦)
這篇文章主要介紹了使用C++和Direct3D (d3d)獲取屏幕截圖并根據(jù)傳入分辨率進行縮放圖片大小,本文給大家講解的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-04-04
詳解C語言中strcpy()函數(shù)與strncpy()函數(shù)的使用
這篇文章主要介紹了詳解C語言中strcpy()函數(shù)與strncpy()函數(shù)的使用,是C語言入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下2015-08-08
C++實現(xiàn)學(xué)生信息管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C++實現(xiàn)學(xué)生信息管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-12-12

