免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 12068 | 回复: 12
打印 上一主题 下一主题

字符串A中插入字符串B [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-02-16 00:31 |只看该作者 |倒序浏览
最近做一个项目 要在字符串中插入另外字符串。 大家谁能给一个好的算法?可以用库函数,但是执行效率一定要高。

例如 char srcptr[255]="<sip: 12345@10.84.22.200;context=phone>"
我想在字符@前面插入一个字符串 ;paid=72 最终得到下面这个字符串

<sip: 12345;paid=72@10.84.22.200;context=phone>;

请问执行时间最少的算法是什么?可以用库函数。

论坛徽章:
0
2 [报告]
发表于 2012-02-16 00:36 |只看该作者
我是这样写的,但是我觉得写的太烂了,希望大家能给出好的算法。
char srcptr[255]="<sip: 12345@10.84.22.200;context=phone>"
val=72;
char tmpstr[255];
int msgLen=strstr(srcptr,"@")-srcptr;
strncpy(tmpstr,srcptr,msgLen);
msgLen += sprintf(tmpstr,";paid=%s",val);
strcpy(srcptr+msgLen,strstr(srcptr,"@");
strcpy(srcptr,tmpstr);

论坛徽章:
0
3 [报告]
发表于 2012-02-16 01:20 |只看该作者
如果现在效率不是瓶颈,那么任然用str*系列函数,因为旁生枝节最少。
如果非要求效率,并且知道大小,那么用mem*系列函数函数最快,对各种u有优化。
如果任然要求效率,那么你可以考虑OwnWaterloo在http://bbs.chinaunix.net/thread-3669543-15-1.html中说的list+char这种方式,这个应该是最快的了。但是估计你用不上,徒增很多复杂性。

论坛徽章:
2
射手座
日期:2014-10-10 15:59:4715-16赛季CBA联赛之上海
日期:2016-03-03 10:27:14
4 [报告]
发表于 2012-02-16 01:22 |只看该作者
回复 1# littlezlt


    str.insert(str.find("@"),"xxx")

论坛徽章:
0
5 [报告]
发表于 2012-02-16 10:30 |只看该作者
回复 4# yinyuemi

我们用的是纯种的C语言哪有你说的那么多性质。
   

论坛徽章:
324
射手座
日期:2013-08-23 12:04:38射手座
日期:2013-08-23 16:18:12未羊
日期:2013-08-30 14:33:15水瓶座
日期:2013-09-02 16:44:31摩羯座
日期:2013-09-25 09:33:52双子座
日期:2013-09-26 12:21:10金牛座
日期:2013-10-14 09:08:49申猴
日期:2013-10-16 13:09:43子鼠
日期:2013-10-17 23:23:19射手座
日期:2013-10-18 13:00:27金牛座
日期:2013-10-18 15:47:57午马
日期:2013-10-18 21:43:38
6 [报告]
发表于 2012-02-16 10:54 |只看该作者
算法上没用更好的办法,只能在写法上下工夫

论坛徽章:
0
7 [报告]
发表于 2012-02-16 11:02 |只看该作者
本帖最后由 三月廿七 于 2012-02-16 11:06 编辑

1:统计字符串中 @的个数
2:开个内存复制,malloc(getAtcount() * strlen(s1) + strlen(s2) + 1);
复杂度为 getAtcount() * strlen(s1)

这种代码一般只需要计算一次(我猜的对不对??)
不管是什么算法都无所谓,完全可以忽略不计

论坛徽章:
0
8 [报告]
发表于 2012-02-16 22:22 |只看该作者
先把@10.84.22.200;context=phone>"接到;paid=72后面,再把这个串接到<sip:12345后面

论坛徽章:
36
子鼠
日期:2013-08-28 22:23:29黄金圣斗士
日期:2015-12-01 11:37:51程序设计版块每日发帖之星
日期:2015-12-14 06:20:00CU十四周年纪念徽章
日期:2015-12-22 16:50:40IT运维版块每日发帖之星
日期:2016-01-25 06:20:0015-16赛季CBA联赛之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之福建
日期:2016-04-07 11:25:2215-16赛季CBA联赛之青岛
日期:2016-04-29 18:02:5915-16赛季CBA联赛之北控
日期:2016-06-20 17:38:50技术图书徽章
日期:2016-07-19 13:54:03程序设计版块每日发帖之星
日期:2016-08-21 06:20:00
9 [报告]
发表于 2012-02-16 22:42 |只看该作者
本帖最后由 cokeboL 于 2012-02-17 19:23 编辑

从后面开始复制,没验证,位置什么的楼主再推敲推敲。可以加第三个参数指明在哪个字符前面插入,看需求吧
时间复杂度大概是俩字符串长度和减去插入位置前面的长度。这个应该是最快的了吧大概
  1. void str_insert(char *src, char *insert)
  2. {
  3.     char *tail=src+strlen(src)+strlen(insert);
  4.     char *src_tail=src+strlen(src);
  5.     while(*(tail+1) != '@'){
  6.         *tail--=*src_tail--;
  7.     }
  8.     src_tail=insert+strlen(insert)-1;
  9.     while(src_tail >= insert){
  10.         *tail--=*src_tail--;
  11.     }
  12. }   

复制代码

论坛徽章:
0
10 [报告]
发表于 2012-02-16 22:42 |只看该作者
可以考虑正值表达式,regcomp和regexec函数
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP