字符串p型编码(信息学奥赛一本通-T1145)
生活随笔
收集整理的這篇文章主要介紹了
字符串p型编码(信息学奥赛一本通-T1145)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
【題目描述】
給定一個完全由數字字符(‘0’,‘1’,‘2’,…,‘9’)構成的字符串str,請寫出str的p型編碼串。例如:字符串122344111可被描述為"1個1、2個2、1個3、2個4、3個1",因此我們說122344111的p型編碼串為1122132431;類似的道理,編碼串101可以用來描述1111111111;00000000000可描述為"11個0",因此它的p型編碼串即為110;100200300可描述為"1個1、2個 0、1個2、2個0、1個3、2個0",因此它的p型編碼串為112012201320。
【輸入】
輸入僅一行,包含字符串str。每一行字符串最多包含1000個數字字符。
【輸出】
輸出該字符串對應的p型編碼串。
【輸入樣例】
122344111
【輸出樣例】
1122132431
【源程序】
#include<iostream> #include<cstdio> #include<cstring> using namespace std; int main() {char s[1000];int len,position;int sum=1;int i;gets(s);//獲取字符串slen=strlen(s);//求字符串長度for(i=0; i<len; i++){if(s[i]==s[i+1]) sum++;//若第i個與第i+1個數字相同,累加連續出現次數else{cout<<sum<<s[i];//無法連續時,輸出第i個數字連續出現次數與該數字sum=1;//開始累加第i+1個數字的連續出現次數}}cout<<endl;return 0; }總結
以上是生活随笔為你收集整理的字符串p型编码(信息学奥赛一本通-T1145)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 保留12位小数的浮点数(信息学奥赛一本通
- 下一篇: 判断字符串是否为回文(信息学奥赛一本通-