青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

qinzuoyan

  C++博客 :: 首頁 :: 聯系 :: 聚合  :: 管理
  8 Posts :: 0 Stories :: 16 Comments :: 0 Trackbacks

常用鏈接

留言簿(3)

我參與的團隊

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

實現這個函數:
char* strrep(const char* src,  const char* from, const char* to)
{
}

將src中出現的所有from替換成to
時間:
10分鐘。

要求:
1. 功能正確,盡量高效
2.不能調用現有的正則表達式庫
3.可以使用strdup,malloc,realloc等函數,以及其他的c字符串 操作函數
4.估算你所寫算法的時間復雜度



#include 
<string.h>
#include 
<malloc.h>

/**
 * On success, strrep() returns a newly allocated string, which is constructed by replacing all substring `from' in `src' with `to'.
 * If `from' is a null string(with length of 1), then return a duplication of `src'.
 *
 * On failure
 *   ENOMEM Insufficient memory is available.
 * 
 * src is a null-terminated string.
 * from is a null-terminated string.
 * to is a null-terminated string.
 * 
 
*/
char* strrep(const char* src,  const char* from, const char* to)
{
  
char *des, *des_cur;
  
int from_len, to_len, src_len, des_len;
  
const char *src_cur, *src_end, *occ;
  
const char **marks; 
  
int mark_len, m, rep_count;
  
// prepare
  from_len = strlen(from);
  to_len 
= strlen(to);
  src_len 
= strlen(src);
  
if (from_len == 0)
    
return strdup(src);
  
// mark all occurence of `from' in `src'
  mark_len = 0x4;
  marks 
= (const char**)malloc(sizeof(char** mark_len);
  
if (marks == NULL)
    
return NULL;
  rep_count 
= 0;
  src_cur 
= src;
  
while((occ = strstr(src_cur, from)) != NULL) {
    rep_count
++;
    
// need more space for mark
    if (rep_count > mark_len) {
      mark_len 
<< 1;
      marks 
= (const char**)realloc(marks, mark_len);
      
if (marks == NULL)
        
return NULL;
    }
    
// mark the position
    marks[rep_count - 1= occ;
    
// find next occurence from the current position
    src_cur = occ + from_len;
  }
  
// construct new string
  des_len = src_len + (to_len - from_len) * rep_count;
  des 
= (char*)malloc(des_len + 1);
  
if (des == NULL)
    
return NULL;
  des_cur 
= des;
  src_cur 
= src;
  m 
= 0;
  
if (m < rep_count)
    occ 
= marks[m];
  
else
    occ 
= NULL;
  
while(*src_cur) {
    
if (src_cur != occ)
      
*des_cur++ = *src_cur++;
    
else {
      
// replace `from' with `to'
      strncpy(des_cur, to, to_len);
      src_cur 
+= from_len;
      des_cur 
+= to_len;
      
// more to replace?
      m++;
      
if (m < rep_count)
        occ 
= marks[m];
      
else
        occ 
= NULL;
    }
  }
  des_cur 
= '\0';
  free(marks);
  
return des;
}


posted on 2010-06-10 12:16 左言 閱讀(2370) 評論(1)  編輯 收藏 引用

Feedback

# re: 一道筆試題 - strrep()函數的實現[未登錄] 2010-06-11 10:58 expter
KMp不就行了嗎?  回復  更多評論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久激情视频久久| 欧美日韩在线一区二区| 另类图片国产| 久久久久九九九九| 久久婷婷久久| 麻豆av福利av久久av| 免费不卡亚洲欧美| 亚洲国产精品久久久久秋霞影院 | 欧美激情综合| 亚洲国产高清在线| 亚洲午夜高清视频| 国产精品一区二区久久精品| 国产日韩免费| 亚洲高清电影| 一个色综合av| 久久精品视频99| 欧美激情第1页| 日韩一级精品视频在线观看| 亚洲欧美国产三级| 欧美一区三区三区高中清蜜桃 | 国产喷白浆一区二区三区 | 99国产精品久久| 亚洲欧美日韩精品| 免费看成人av| 亚洲一区国产精品| 久久久人成影片一区二区三区| 欧美福利一区二区| 国产亚洲福利| 一个人看的www久久| 久久久蜜桃精品| 99re成人精品视频| 免费亚洲电影在线| 韩国av一区二区三区| 亚洲影院免费观看| 欧美激情a∨在线视频播放| 亚洲制服丝袜在线| 欧美日本国产一区| 亚洲国产精品高清久久久| 欧美一区三区三区高中清蜜桃| 91久久香蕉国产日韩欧美9色| 欧美专区在线观看| 国产精品午夜电影| 亚洲性图久久| 亚洲毛片在线免费观看| 久久精品视频免费| 国产日韩一区二区| 欧美在线你懂的| 亚洲伊人观看| 国产精品久久久91| 中文精品视频| 亚洲精品一区二区网址 | 狠狠综合久久av一区二区老牛| 亚洲天堂视频在线观看| 91久久精品视频| 欧美大片一区二区三区| 怡红院精品视频| 久久中文字幕一区| 欧美美女喷水视频| 国产亚洲欧美色| 久久电影一区| 欧美在线免费看| 国产主播一区| 久久久午夜视频| 久久精品国产欧美激情| 狠狠爱综合网| 蜜臀va亚洲va欧美va天堂| 久久九九热re6这里有精品| 国内精品久久久久影院优| 久久一区二区三区四区| 久久久久久久波多野高潮日日| 国产一区二区欧美| 久久中文在线| 欧美激情视频一区二区三区免费| 欧美精品首页| 亚洲美女尤物影院| 亚洲免费成人av电影| 国产精品国产三级国产专区53| 亚洲午夜精品久久久久久app| 国产精品99久久久久久白浆小说| 国产精品videosex极品| 午夜久久福利| 欧美有码在线观看视频| 亚洲欧洲日产国产网站| 日韩网站免费观看| 国产欧美亚洲精品| 欧美成黄导航| 欧美日韩国产另类不卡| 亚洲女女女同性video| 久久精品男女| 亚洲国产欧美一区| 午夜久久美女| 伊人成人开心激情综合网| 久久亚洲电影| 久久综合九色综合欧美狠狠| 亚洲黄色视屏| 亚洲一区二区三区精品视频| 国产亚洲精品久久飘花| 欧美成人综合网站| 欧美三级网址| 噜噜噜91成人网| 欧美日韩网站| 看欧美日韩国产| 欧美韩日视频| 久久久久久9999| 欧美日韩午夜激情| 欧美成人精品一区| 国产精品综合网站| 亚洲特黄一级片| 亚洲自拍偷拍视频| 好看的日韩视频| 99精品福利视频| 一区二区在线观看视频| 亚洲精品一区在线观看香蕉| 国产欧美韩国高清| 亚洲免费观看高清完整版在线观看熊 | 欧美成人精品影院| 久久精品一本久久99精品| 欧美日韩精品免费观看视一区二区 | 久久精品一区二区三区四区| 日韩一级免费观看| 欧美一区二区三区在线视频 | 国产女人精品视频| 欧美xx视频| 亚洲欧美成aⅴ人在线观看| 在线观看亚洲精品| 亚洲欧美中文另类| 亚洲美女视频在线免费观看| 久久精品欧美日韩| 午夜精品久久久久久久白皮肤 | 一区二区三区在线免费视频| 亚洲一区在线观看免费观看电影高清| 日韩天堂av| 欧美激情按摩| 亚洲高清电影| 老鸭窝毛片一区二区三区| 久久精品国产免费观看| 欧美激情一级片一区二区| 久久青草久久| 国产亚洲欧美一级| 亚洲欧美另类在线| 亚洲欧美三级伦理| 欧美视频在线观看免费网址| 欧美激情一区二区三级高清视频| 激情久久久久久| 久久久久一本一区二区青青蜜月| 久久婷婷丁香| 亚洲国产精品久久人人爱蜜臀| 久久久久久久久久久成人| 久久亚洲欧美| 亚洲黄色免费| 欧美日韩国产影院| 中文久久精品| 欧美一区二区三区视频在线| 国产伦精品一区二区三区视频孕妇 | 国产精品一区久久| 一本久道久久综合婷婷鲸鱼| 亚洲精品久久| 欧美极品一区| 一本一本久久| 欧美一区二区三区视频在线 | 国产亚洲一区在线播放| 久久精品国产清自在天天线| 久久阴道视频| 亚洲欧洲一区二区在线观看 | 欧美亚洲专区| 欧美成人午夜激情在线| 亚洲精品美女久久久久| 欧美日韩在线综合| 亚洲永久网站| 亚洲国产日韩欧美| 亚洲欧美激情一区二区| 韩国女主播一区二区三区| 欧美91视频| 午夜久久电影网| 亚洲黄页一区| 国产精品色婷婷久久58| 久久国产精品一区二区| 亚洲国产小视频| 久久国产精品久久久| 亚洲黄色视屏| 国产亚洲欧洲| 欧美日本一区二区三区| 欧美一级片久久久久久久| 欧美国产第二页| 欧美怡红院视频| 在线视频日韩| 1024精品一区二区三区| 欧美性大战久久久久| 久久久噜噜噜久久| 亚洲一级黄色片| 亚洲日本中文字幕| 欧美成人性生活| 久久精品久久99精品久久| 中日韩视频在线观看| 亚洲黄色免费| 在线免费观看日韩欧美| 国产伦精品一区二区三区视频孕妇| 女人香蕉久久**毛片精品| 欧美亚洲在线视频| 亚洲自拍啪啪|