#include<stdio.h>
#include<stdlib.h>
int strTime(const char *str1, const char *str2, int *time)
{
int count = 0;
char *p1 = str1;
char *p2 = str2;
//p1是第一次出现的位置
p1 = strstr(p1, p2);
//注意这里不要写成*p1!=NULL 由于p1 是null的地址一旦读取*p1 会出错的!!!!不能读取操作系统的数据
//千万不要写成 *p
//while (*p1 != '\0')
//while (p1 != NULL)
while (p1)
{
count++;
//让指针向后移动str2长度个位置
p1 = p1+strlen(str2);
//找到下一次出现的位置
p1 = strstr(p1, p2);
}
*time = count;
return 1;
}
//这里也能够实现出现次数的查询
 /*int strTime(const char *str1, const char *str2, int *time)
{
char *p = NULL;
int count = 0;
char *sub = NULL;
p = str1;
sub = str2;
do
{
p = strstr(p, sub);
if (p != NULL)
{
count++;
p = p + strlen(sub);
}
else
{
break;
}
} while (*p != '\0');
*time = count;
}*/ int getRes2(const char *str, const char *substr, int *time, char **buf2)
{
char *buf = (char *)malloc(strlen(str)*sizeof(char));
char *pbuf = buf;
//进行字符串的替换
char *p = NULL;
char *sub = NULL;
p = str;
sub = substr;
int flag = 4;
//仅仅要是不相等的情况下就将字符复制到buf中
char *point = "dcba";
while (*p != '\0')
{
if (*p != *sub)
{
*buf = *p;
buf++;
p++;
//printf("%s\n", pbuf);
}
//想等情况下也就是找到了须要替换的位置
else
{
for (int i = 0; i < flag; i++)
{
*buf = *point;
buf++;
point++;
// printf("%s\n", pbuf);
}
//控制4321循环
flag--;
//这里须要将离开了"dcba"首地址的指针又一次定位回去
point = "dcba";
if (flag == 0)
{
flag = 4;
}
//相等的时候须要让p指针跨越四个字节也就是他下一次进行查找的位置
p += 4;
}
}
//对末尾的加上字符串结束标志防止输出时乱码
*buf = '\0';
//二级指针的典型使用方法
 *buf2 = pbuf;
}
void main()
{
char *str1 = "abcd11111abcd2222abcdqqqqqabcd11111abcd2222abcdqqqqqabcd11111abcd2222abcdqqqqq";
char *str2 = "abcd"; int time = 0;
//1求字符串"abcd"出现的次数
strTime(str1, str2, &time);
printf("出现的次数是%d\n", time);
char *buf = NULL;
//把字符串替换成(dcba11111dcb2222dqqqqqdd11111dcba.....)
//注意特点逆序后,每次字符少一个,四次一循环;
getRes2(str1, str2, &time, &buf);
printf("原来的字符串 %s\n", str1);
printf("替换后的字符串 %s\n", buf);
system("pause");
}

【通过操作指针,与指针做函数參数&#39;实现字串在主串中出现的次数,然后将出现的部分依照要求进行替换 】的更多相关文章

  1. Effective JavaScript Item 55 接受配置对象作为函数參数

    接受配置对象作为函数參数 尽管保持函数接受的參数的顺序非常重要,可是当函数可以接受的參数达到一定数量时.也会让用户非常头疼: var alert = new Alert(100, 75, 300, 2 ...

  2. C++容器类对象函数參数问题

    总之中的一个句话:容器类对象作为函数參数,与整数类型作为函数參数的传递特性同样. 验证程序 #include "stdafx.h" #include <iostream> ...

  3. JavaScript的最大函数參数长度和最大栈深度检測

    一般代码也许不会涉及最大參数长度和最大栈深度,但某些特殊场合,检測这两个參数还是有必要的.比如:用递归计算斐波那契数列的第n个值,不了解最大栈深度,难免显得肤浅.又比如:将一串charCode转成St ...

  4. 各种python 函数參数定义和解析

    python 中的函数參数是赋值式的传递的,函数的使用中要注意两个方面:1.函数參数的定义过程,2.函数參数在调用过程中是怎样解析的. 首先说一下在python 中的函数调用过程是分四种方式的.这里且 ...

  5. cmake函数參数解析

    近期在迁移公司的make系统到cmake上.发现cmake的function參数非常奇怪.比如,假设我们向一个function传递list作为參数,在function中,形參会变成例如以下状况: se ...

  6. C语言函数參数传递原理

    C语言中參数的传递方式一般存在两种方式:一种是通过栈的形式传递.还有一种是通过寄存器的方式传递的. 这次.我们仅仅是具体描写叙述一下第一种參数传递方式,第二种方式在这里不做具体介绍. 首先,我们看一下 ...

  7. C语言中的system函数參数具体解释

    http://blog.csdn.net/pipisorry/article/details/33024727 函数名: system 功   能: 发出一个DOS命令   用   法: int sy ...

  8. 【VBA研究】VBA自己定义函数參数类型不符的错误

    版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/iamlaosong/article/details/36871769 作者:iamlaosong 1 ...

  9. C/C++——指针,引用做函数形参

    函数中的形参是普通形参的时,函数只是操纵的实参的副本,而无法去修改实参. 引用形参是对实参的直接操纵,指针形参是对 它所指向的值(*p) 的直接操纵,但是对于这个指针变量(p)来说,依然只是副本. 指 ...

随机推荐

  1. python使用smtplib库和smtp.qq.com邮件服务器发送邮件(转)

    使用qq的邮件服务器需要注意的两个地方主要是: 1.协议问题 使用465端口 SSL 协议 2.口令问题 出现SMTPAuthenticationError 主要的原因就是口令和帐号信息不对,这里我们 ...

  2. 好大滴坑, Spring MVC覆盖了Trsaction

    好大滴坑. Spring MVC覆盖了Trsaction 解决方式: <!-- package-scan 4 Spring MVC --> <context:component-sc ...

  3. Dev GridView RowCellClick活动MouseDown事件

    GridView可编辑.在无声的思想左键点击"进入编辑". 将GridView的OptionsColumn.AllowEdit至false离开时触发RowCellClick. 但有 ...

  4. jQuery的使用及关于框架造型(转)

    Introduction 正如jQuery所宣称的一样,Write Less, Do More.很多时候我们喜欢用它来解决问题.但增加一个库必然意味着更大的网络负担,意味着更高的页面初始载入时间.并且 ...

  5. MVC中使用SignalR

    MVC中使用SignalR打造酷炫实用的即时通讯功能附源码   前言,现在这世道写篇帖子没个前言真不好意思发出来.本贴的主要内容来自于本人在之前项目中所开发的一个小功能,用于OA中的即时通讯.由于当时 ...

  6. Linux/UNIX先进I/O

    先进I/O 非阻塞IO 非阻塞I/O因此,我们可以称之为open.read和write这种I/O操作,而这些操作不会永久阻止.我们假设,该操作不能完成,然后调用立即返回一个错误.则表示该操作将继续作为 ...

  7. JavaEE(9) - Session EJB的生命周期、事务及拦截器

    1. SessionBean的生命周期 无状态Session Bean: 不存在状态-->待命状态-->被销毁状态 不存在状态-->待命状态: 1)通过构造器创建EJB实例 2)执行 ...

  8. UVA1232 - SKYLINE(段树部分的变化)

    UVA1232 - SKYLINE(线段树区间改动) 题目链接 题目大意:依照顺序盖楼.假设这个位置(当前要盖的楼覆盖范围内)要新建的楼的高度>=之前就有的最大高度,那么就+1.最后输出这个+1 ...

  9. ZOJ3605-Find the Marble(可能性DP)

    Find the Marble Time Limit: 2 Seconds      Memory Limit: 65536 KB Alice and Bob are playing a game. ...

  10. 開始开发 Dashboard Widgets,第2章,读书笔记

    文件夹:http://blog.csdn.net/wide288/article/details/40298693 主要内容: widgets 的组成是什么. 怎么创建 info.plist 文件 怎 ...