(1)
(1)程序编写如下:
#include<stdio.h>
#include<string.h>
void delete_str(char*s,char*t,char*u)
{
int i=0,j=0,temp=0;
//一次拿出一个s中的字符与t字符数组进行比较
for(i=0;(*(s+i)) != '\0';i++)
{
for(j=0;(*(t+j)) !='\0';j++)
{
if(*(s+i) != *(t+j))//temp用来计算s里面的这一个字符与t字符数组有多少个不一样
{
temp++;
}
if(temp == strlen(t))//如果s的字符与t里面的字符都不一样,那这个值就被写进u里面
{
*(u++) = *(s+i);//写入u中
}
}
temp = 0;//temp写0,比较s的下一个字符与t字符数组
}
*u='\0';//给u字符数组最后加上反斜杠0
}
int main(void)
{
char s[]="112345";
char t[]="2467";
char u[10];
delete_str(s,t,u);
printf("%s\n",u);
return 0;
}
程序实现效果:
(2)程序如下:
#include<stdio.h>
int_arr_compare(int len1,int *array1,int len2,int *array2)
{
int cnt=0;
int *p1 = array1+len1-1; //指向array1数组的最后一个元素
int *p2 = array2+len2-1;
int min_len = (len1>len2)?len2:len1;//看到底依次比较多少次
while(min_len--)
{
if(*p1-- != *p2--)
cnt++; //不相等时cnt计数
}
return cnt;//返回cnt的值
}
int main(void)
{
int arr1[]={1,3,5};
int arr2[]={1,3,5,7};
//调用函数
int ret = int_arr_compare(3,arr1,4,arr2);
printf("%d\n",ret);
return 0;
}
程序运行如下: