勤于测试前面学过的知识之测试题

在学习的过程中,不要一味地去学习新知识,温故以前学习的知识也是很有必要的:下面是我自己前几天测试自己的一些基本的试题;拿出来分享一下

1.写一个指针数组;

2.写一个数组指针;

3.写一个函数指针;

4.写一个函数指针数组;

5.写一个函数指针数组指针;

6.用自己的话解释含义:  int*  (  *fun  (  double , char* )  ) (   char*,   int**  );

7.模拟实现strstr;

8.迷你实现strcpy;

以上是本人对自己的测试题;如有兴趣大家可以动手写一写;都是一些和基础的东西;


我的解答:

1.int*  arr[10]={0};

2.int  (*arr)[10]=NULL;

3.int  ( *fun ) (int,int);

4.int   ( *fun[10] )(int ,int);

5..int   (* (*fun)[10] )(int ,int);

6.  解释这个:int*  (   ) (   char*,   int**  );

解释含义:首先fun是一个函数声明;这个函数有两个参数,第一个参数是double类型,第二个参数是char*类型;这个函数的返回值是一个函数指针类型,这个函数指针类型的指针可以指向一个函数,能够指向的这个函数的类型是:第一个采纳数为char*,第二个参数为int**,返回值为int*。

相当于这么写: int*(*)(char*, int**)    fun(  double , char* );这样写就是普通函数定义的模式;大家也可以很好的理解;

7.模式实现strstr

strstr;查找一个字符串的字串是否存在;若果查找的字符串在原字符串中;则输出该字符串在原字符串首字符的位置;

程序实现:

#include<stdio.h>
#include<assert.h>
#include<string.h>
char* my_strstr(const char*s1,const char*s2)
{
	const char*str1=s1;
	const char*str2=s2;
	const char*p1=NULL;
	assert(s1);
	assert(s2);
	while(*str1)
	{
		p1=str1;//用p1空指针保存每次进来的str1的地址;
		while((*str1==*str2)&&*str1&&*str2) //当条件成立时                                   
		{
                         str1++;       //str1和str2向后移动;
			 str2++;
		}
		if(*str2=='\0')//如果str2走到'\0'了说明找到了
		{
			return (char*)p1;//返回str1进入循环时的初地址
		}
	else
	str1=p1+1;<strong><span style="font-size:24px;"><span style="font-size: 24px;"></span></span></strong><pre name="code" class="cpp">           //如果没有找到则str1在进入循环的初位置向后挪动一个字符;
str2=s2;//str2回到原始位置}return NULL;}int main(){char *p1="aaadeffffdefcccc";char *p2="def";char *p3=my_strstr(p1,p2);printf("%s",p3); return 0;}

 讲解: 
 

勤于测试前面学过的知识之测试题_第1张图片

8.模拟实现strcpy

含义:讲一个字符串拷贝到另一个字符串中;注意:'\0'一起拷贝进去;

代码实现:

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
  
char *my_strcpy(char *dest, char *src)
{
    assert(dest);
    assert(src);
    char *ret = dest;
    while ((*dest++ = *src++) )//连同‘\0’一起拷贝了
    {
        ;
    }
      
    /*while (*src)
    {
        *dest = *src;
        dest++;
        src++;
    }*/
    //原串为‘\0’时跳出,并未拷贝‘\0’,要赋值*dest = '\0'
    //*dest = '\0';
    return ret;
    //自加有副作用,因此return dest 可能读到最后'\0'就不输出了
}
 
 
ok!!!!继续加油!
 

你可能感兴趣的:(勤于测试前面学过的知识之测试题)