肯尼斯·里科《C和指针》第6章 指针(6)编程的练习:查找字符

1.编写一个函数,它在一个字符串中进行搜索,查找在一个给定字符集合中出现的所有字符。这个函数的原型如下:

cpp 复制代码
char *find_char( char const *source, char const *chars );

它的基本想法是查找source字符串中匹配chars字符串中任何字符的第1个字符,然后返回一个指向source中第1个匹配所找到的位置的指针。如果source中的所有字符均不匹配chars中的任何字符,就返回一个NULL指针。如果任何一个参数为NULL,或任何一个参数所指向的字符串为空,函数也返回一个NULL指针。**举个例子,假定source指向ABCDEF,如果chars指向XYZ、JURY或QQQQ,函数就返回一个NULL指针;如果chars指向XRCQEF,函数就返回一个指向source中C字符的指针。**参数所指向的字符串是绝不会被修改的。

碰巧,C函数库中存在一个名叫strpbrk的函数,它的功能几乎和这个要编写的函数一模一样。但这个程序的目的是让你自己练习操纵指针,所以:a.不应该使用任何用于操纵字符串的库函数(如strcpy、strcmp、index等);b.函数中的任何地方都不应该使用下标引用。

书没有答案,下面是我自己写的:

cpp 复制代码
#include <stdio.h>
#include <stdlib.h>

char *find_char(char const *source, char const *chars)
{
    char* sol = NULL;
    char* s_str;
    char* c_str;
 
    for(s_str = source; *s_str != '\0'; s_str++){
        for(c_str = chars; *c_str != '\0'; c_str++){
            if(*c_str == *s_str){
                sol = s_str;
                printf("%c",*sol);
            }
        }
    }
    return sol;
}

int main(){
    char const source[] = "ABCDEF";
    char const  chars[] = "XRCQEF";
    find_char(source, chars);
}

在虚拟机里运行了一下,是可以的。但是是否存在其他bug,还需要调试一下。

相关推荐
2401_876907521 小时前
Python基础笔记
笔记
风已经起了1 小时前
FPGA学习笔记——IIC协议简介
笔记·学习·fpga开发
牧子与羊1 小时前
自学中医笔记(二)
笔记
lingggggaaaa1 小时前
小迪安全v2023学习笔记(六十二讲)—— PHP框架反序列化
笔记·学习·安全·web安全·网络安全·php·反序列化
我们从未走散3 小时前
JVM学习笔记-----StringTable
jvm·笔记·学习
胡萝卜3.03 小时前
数据结构初阶:排序算法(一)插入排序、选择排序
数据结构·笔记·学习·算法·排序算法·学习方法
阿巴~阿巴~4 小时前
冒泡排序算法
c语言·开发语言·算法·排序算法
xinzheng新政4 小时前
纸板制造制胶工艺学习记录4
学习·制造
我们从未走散6 小时前
JVM学习笔记-----类加载
笔记·学习
前路不黑暗@7 小时前
C语言:操作符详解(二)
c语言·开发语言·经验分享·笔记·学习·学习方法·visual studio