左旋轉字符串
題目:
定義字符串的左旋轉操作:把字符串前面的若干個字符移動到字符串的尾部。
如把字符串 abcdef 左旋轉 2 位得到字符串 cdefab。請實現字符串左旋轉的函數。
要求時間對長度為 n 的字符串操作的復雜度為 O(n),輔助內存為 O(1)。
分析:
網上看到解法很多種,就不詳細說明了。
我采用的是數組不對稱的交換時間復雜度應該是O(n)。
代碼實現(GCC編譯通過):
#include "stdio.h"#include "stdlib.h" void reverse_str(char str[],int n,int m); int main(void){ char str[] = "abcdef"; reverse_str(str,6,2); return 0;} //str為字符串數組,n為數組長度,m為左移位數void reverse_str(char str[],int n,int m){ int i,j; char tmp; for(i=0,j=n-1;i<j;i++,j--) { tmp = str[i]; str[i] = str[j]; str[j] = tmp; } for(i=0,j=n-m-1;i<j;i++,j--) { tmp = str[i]; str[i] = str[j]; str[j] = tmp; } for(i=n-m,j=n-1;i<j;i++,j--) { tmp = str[i]; str[i] = str[j]; str[j] = tmp; } printf("%s/n",str);}
翻轉句子中單詞順序
翻轉句子中單詞的順序。
題目:
輸入一個英文句子,翻轉句子中單詞的順序,但單詞內字符的順序不變。
句子中單詞以空格符隔開。為簡單起見,標點符號和普通字母一樣處理。
例如輸入“I am a student.”,則輸出“student. a am I”。
這個題比較簡單,直接上代碼了(GCC編譯通過)
代碼實現:
#include "stdio.h"#include "stdlib.h" void helper(char a[],int n); int main(void){ char str[15] = "I am a student!"; helper(str,15); printf("/n"); return 0;} void helper(char a[],int n){ int e = n-1; int i,j,t; for(i=e;i>=0;i=j-1) { for(j=i;j>=0 && a[j]!=' ' ;--j); t=j+1; while(t<=i) printf("%c",a[t++]); if(j<0) return; else printf(" "); }}
新聞熱點
疑難解答
圖片精選