C語言字符串快速壓縮算法代碼
大家知道C語言字符串快速壓縮算法是怎麼樣的嗎?下面小編為大家整理了C語言字符串快速壓縮算法代碼,希望能幫到大家!
通過鍵盤輸入一串小寫字母(a~z)組成的字符串。
請編寫一個字符串壓縮程序,將字符串中連續出席的`重複字母進行壓縮,並輸出壓縮後的字符串。
壓縮規則:
1、僅壓縮連續重複出現的字符。比如字符串”abcbc”由於無連續重複字符,壓縮後的字符串還是”abcbc”。
2、壓縮字段的格式為”字符重複的次數+字符”。例如:字符串”xxxyyyyyyz”壓縮後就成為”3x6yz”。
輸入:“cccddecc” 輸出:“3c2de2c”
輸入:“adef” 輸出:“adef”
輸入:“pppppppp” 輸出:“8p”
主要説來就是進行字符串處理類的問題,主要涉及到:
1.字符串的輸入與輸出;
2.基本常用的C語言的字符串的函數使用;
3.對於多重情況的考慮;
4.將數字轉換成字符串並進行拼接;
複製代碼 代碼如下:
#include
#include
#include
int main()
{
char str[100] = {'};
char res[100] = {'};
scanf("%s",str);
int length = strlen(str);
int i=0, j=0, k=0;
int count = 0;
do
{
if(i < length && str[i++] == str[j])
count++;
if(str[i] != str[j])
{
if(count <= 1)
res[k++] = str[j];
else
{
if(count > 1)
{
char temp[10] = {'};
itoa(count,temp,10);
strcpy(res+k,temp);
k+=strlen(temp);
res[k++] = str[j];
}
}
j = i;
count = 0;
}
}while(i<length);
res[k] = ';
printf("The result is : %sn",res);
return 0;
}
-
C語言數組的定義及引用
引導語:數組是在程序設計中,為了處理方便,把具有相同類型的若干變量按有序的形式組織起來的一種形式。以下是本站小編分享給大家的C語言數組,希望大家喜歡!1.1一維數組的定義、初始化和引用1.一維數組的定義方式為:類型説明符數組名[常量表達式](1)數組名的命名方法...
-
在VS下如何運行C語言程序
微軟後來對VC6.0進行了升級,並更名為VisualStudio(簡稱VS),支持更多的編程語言,更加強大的功能,不過VisualStudio文件很大,有2~3G左右,大部分功能初學者暫時不會用到;而且安裝繁瑣,需要將近半個小時的時間,也不容易卸載乾淨。VisualStudio還有一個缺點是佔用資源較多,不...
-
計算機c語言基礎知識
C語言程序設計是高效計算機專業學生必修的一門基礎課程,那麼你對計算機c語言瞭解多少呢?下面是小編整理的計算機c語言基礎知識,歡迎大家閲讀參考。計算機c語言的特性C語言是世界上最流行、使用最廣泛的高級程序設計語言之一。在操作系統和系統使用程序以及需要對...
-
2017年計算機二級考試C語言備考題及答案
計算機二級對於很多考生來説還是比較有難度的,那麼怎樣順利通過二級考試呢?這就需要大家平時多練習和找方法了。以下是本站小編整理的2017年計算機二級考試C語言備考題及答案,希望對大家有幫助!1.(A)是構成C語言程序的基本單位。A、函數B、過程C、子程序D、子例...