国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C > 正文

C語言字符串快速壓縮算法代碼

2020-01-26 15:09:44
字體:
來源:轉載
供稿:網友

通過鍵盤輸入一串小寫字母(a~z)組成的字符串。
請編寫一個字符串壓縮程序,將字符串中連續出席的重復字母進行壓縮,并輸出壓縮后的字符串。

壓縮規則:

1、僅壓縮連續重復出現的字符。比如字符串”abcbc”由于無連續重復字符,壓縮后的字符串還是”abcbc”。
2、壓縮字段的格式為”字符重復的次數+字符”。例如:字符串”xxxyyyyyyz”壓縮后就成為”3x6yz”。

示例

輸入:“cccddecc” 輸出:“3c2de2c”
輸入:“adef” 輸出:“adef”
輸入:“pppppppp” 輸出:“8p”

主要說來就是進行字符串處理類的問題,主要涉及到:

1.字符串的輸入與輸出;
2.基本常用的C語言的字符串的函數使用;
3.對于多重情況的考慮;
4.將數字轉換成字符串并進行拼接;

復制代碼 代碼如下:

#include <stdio.h> 
#include <string.h> 
#include <stdlib.h> 
int main() 

    char str[100] = {'/0'}; 
    char res[100] = {'/0'}; 
    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] = {'/0'}; 
                    itoa(count,temp,10); 
                    strcpy(res+k,temp); 
                    k+=strlen(temp); 
                    res[k++] = str[j]; 
                } 
            } 
            j = i; 
            count = 0; 
        } 
    }while(i<length); 
    res[k] = '/0'; 
    printf("The result is : %s/n",res); 
    return 0; 

以上就是本文給大家分享的字符串壓縮算法的全部內容了,希望對大家學習C語言能夠有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 江陵县| 米脂县| 珲春市| 宜兰县| 怀宁县| 白沙| 富宁县| 兴化市| 太白县| 晋城| 砀山县| 双牌县| 荔浦县| 仁寿县| 娄底市| 克东县| 石景山区| 宝丰县| 双辽市| 台湾省| 万州区| 静安区| 南充市| 积石山| 长岛县| 曲水县| 忻州市| 拜泉县| 疏勒县| 武清区| 沁源县| 临潭县| 察雅县| 田东县| 澄迈县| 秀山| 巨鹿县| 青阳县| 桓台县| 防城港市| 平塘县|