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

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>
            999亚洲国产精| 亚洲区中文字幕| 亚洲一区二区毛片| 欧美电影美腿模特1979在线看| 欧美一级专区| 亚洲理论电影网| 亚洲午夜激情| 欧美日韩免费看| 亚洲美女av在线播放| 欧美国产高潮xxxx1819| 久久久午夜视频| 狠狠色丁香婷综合久久| 尤物yw午夜国产精品视频明星| 性久久久久久久| 亚洲一区二区在线免费观看视频 | 欧美一区二区视频在线观看2020| 亚洲欧洲精品一区二区| 久久久综合激的五月天| 欧美成人性生活| 亚洲国产精品va在线看黑人 | 老司机成人网| 亚洲国产天堂久久综合| 欧美激情在线观看| 99精品欧美一区二区三区| 男人插女人欧美| 亚洲美女啪啪| 久久成人精品电影| 亚洲欧美日本国产有色| 久久女同精品一区二区| 永久免费视频成人| 亚洲激情电影中文字幕| 亚洲在线视频| 牛牛国产精品| 国产日韩欧美一区二区三区四区| 久久狠狠亚洲综合| 亚洲伦伦在线| 国产精品久久久久久久第一福利| 欧美一区二区三区免费观看视频 | 久久在线视频| 日韩午夜av电影| 一区二区激情小说| 免费影视亚洲| 国内精品视频一区| 欧美成人国产| 欧美性淫爽ww久久久久无| 亚洲成人在线观看视频| 亚洲国产另类久久精品| 国产精品乱码妇女bbbb| 免费成人高清在线视频| 午夜精品成人在线视频| 欧美大香线蕉线伊人久久国产精品| 国产精品对白刺激久久久| 久久xxxx| 亚洲一区二区三| 黄色欧美日韩| 日韩天堂在线视频| 一本久道综合久久精品| 老司机精品福利视频| 欧美风情在线观看| 久久久久国产一区二区三区四区 | 欧美一区二区三区另类| 亚洲精品久久久久| 久久爱www.| 国外精品视频| 亚洲精品国久久99热| 黄色精品一二区| 亚洲免费在线视频| 在线视频欧美日韩精品| 久久青青草综合| 久久黄金**| 久久成人18免费网站| 国产色婷婷国产综合在线理论片a| 亚洲专区免费| 亚洲特级片在线| 亚洲欧洲另类国产综合| 亚洲国产天堂久久综合网| 欧美成人午夜激情在线| 久久久久久97三级| 国产美女搞久久| 久久久久久精| 国产精品欧美久久| av成人免费在线观看| 99天天综合性| 亚洲一区亚洲二区| 国产在线精品成人一区二区三区 | 亚洲伦伦在线| 99这里只有精品| 一区二区三区高清| 国产精品拍天天在线| 亚洲精品中文字幕在线| 亚洲激情不卡| 嫩草国产精品入口| 欧美激情精品久久久| 亚洲国产99| 免费在线国产精品| 亚洲一区二三| 欧美亚洲综合在线| 永久免费精品影视网站| 亚洲激情在线| 国产精品成人一区| 在线视频亚洲| 亚洲成色www8888| 久久精品亚洲国产奇米99| 久久精品一区二区三区四区 | 香蕉av777xxx色综合一区| 久久国产直播| 日韩亚洲欧美在线观看| 欧美成人三级在线| 欧美有码在线视频| 国产日韩精品在线观看| 亚洲国产精品一区在线观看不卡| 欧美日韩在线另类| 亚洲电影第1页| 亚洲精品日韩欧美| 麻豆91精品| 亚洲人成欧美中文字幕| 一本久久综合亚洲鲁鲁| 国产精品社区| 久久综合九色| 亚洲精品社区| 亚洲国产精品免费| 欧美日本一道本在线视频| 久久久一二三| 亚洲高清网站| 欧美色偷偷大香| 亚洲国产精品黑人久久久| 亚洲精品在线免费观看视频| 欧美日韩在线三区| 亚洲国产精品成人一区二区| 国产视频亚洲精品| 久久久国际精品| 亚洲精品一二| 久久九九精品99国产精品| 亚洲欧洲日本mm| 国产精品蜜臀在线观看| 美女网站在线免费欧美精品| 一区二区激情视频| 女主播福利一区| 黄色精品一二区| 亚洲免费中文| 亚洲欧美卡通另类91av| 永久91嫩草亚洲精品人人| 欧美一区不卡| 亚洲清纯自拍| 一本色道久久加勒比88综合| 国产视频久久网| 欧美激情一区二区久久久| 欧美第十八页| 欧美亚洲网站| 国产精品欧美一区二区三区奶水| 亚洲精品在线免费观看视频| 欧美一区亚洲二区| 国产精品久久午夜夜伦鲁鲁| 久久精品国产一区二区电影| 久久精品免费播放| 亚洲视频精选在线| 亚洲国产天堂久久国产91| 蜜臀av在线播放一区二区三区| 亚洲一区二区av电影| 午夜视频在线观看一区二区| 亚洲精品久久7777| 亚洲高清视频一区二区| 欧美激情偷拍| 最新国产の精品合集bt伙计| 久久九九精品| 久久精品国产亚洲a| 精品二区视频| 国产欧美日韩亚洲| 久久久久久欧美| 亚洲综合国产| 亚洲永久精品国产| 先锋影音国产精品| 亚洲一区二区三区中文字幕| 日韩视频免费观看| 国产精品久久久久999| 欧美理论电影在线观看| 欧美极品在线视频| 亚洲男人第一av网站| 在线视频日韩精品| 亚洲女性裸体视频| 欧美激情第二页| 亚洲一区二区黄色| 亚洲小说欧美另类社区| 亚洲午夜久久久久久久久电影网| 国产乱码精品一区二区三区五月婷 | 久久阴道视频| 另类av一区二区| 久久综合五月| 欧美aⅴ一区二区三区视频| 欧美 日韩 国产一区二区在线视频| 亚洲欧洲一区| 亚洲激情视频网站| 一级成人国产| 免费亚洲视频| 亚洲伊人观看| 欧美一区二区视频免费观看| 久久精品日产第一区二区| 狼狼综合久久久久综合网| 欧美福利精品| 久久久久久9|