涉及字符串和指针的程序设计
(1)编写一个函数insert(),其功能是将一个谓语动词(字符串)插入另一个字符串的主语(设主语是单个单词)之后,拼接出一个含义完整的英文句子。要求分别使用数组方法insert1()和指针方法insert2()实现该功能。
(2)设计一个计数函数count(),统计给定字符串中字母的数量、非字母的数量。
(3)主函数:从键盘上输入2个字符串例如“We in the river.”和“swim”,然后调用函数insert()将2个字符串拼接为“We swim in the river.”,在主函数中输出拼接后的字符串,再调用函数count()统计(非)字母的数量,并在主函数中输出。
# 运行程序并验证输出如下的结果:
初始字符串1:We in the river.
初始字符串2:swim
字符串拼接结果:We swim in the river.
拼接字符串的字母数量:16
拼接字符串的非字母数量:5
初始字符串1:Dogs meat.
初始字符串2:eat
字符串拼接结果:Dogs eat meat.
拼接字符串的字母数量:11
拼接字符串的非字母数量:3
数组实现:
//数组
#include<stdio.h>
#define N 999
void insert(char a[],char b[])
{
int i,j,k=0;
char c[N];
for(i=0;a[i]!=' ';i++)
c[i]=a[i];
k=i;
c[i++]=' ';
for(j=0;b[j]!='\0';i++,j++)
c[i]=b[j];
for(i,k;a[k]!='\0';i++,k++)
c[i]=a[k];
c[i]='\0';
for(j=0;c[j]!='\0';j++)
a[j]=c[j];
a[j]='\0';
}
void count(char a[],int *m,int *n)
{
int i;
for(i=0;a[i]!='\0';i++)
{
if((a[i]>='a'&&a[i]<='z')||(a[i]>='A'&&a[i]<='Z'))
(*m)++;
else
(*n)++;
}
}
int main()
{
int *m,*n;
int count1=0,count2=0;
char a[N],b[N];
m=&count1;
n=&count2;
printf("str1:");
gets(a);
printf("str2:");
gets(b);
insert(a,b);
count(a,m,n);
printf("字符串拼接结果:");
puts(a);
printf("字母数量:%d\n",count1);
printf("非字母数量:%d\n",count2);
return 0;
}
指针实现:
#include<stdio.h>
#define N 999
void insert(char *a,char *b)
{
int i,j,k=0;
char c[N];
for(i=0;*(a+i)!=' ';i++)
*(c+i)=*(a+i);
k=i;
*(c+i++)=' ';
for(j=0;*(b+j)!='\0';i++,j++)
*(c+i)=*(b+j);
for(i,k;*(a+k)!='\0';i++,k++)
*(c+i)=*(a+k);
*(c+i)='\0';
for(j=0;*(c+j)!='\0';j++)
*(a+j)=*(c+j);
*(a+j)='\0';
}
void count(char *a,int *m,int *n)
{
int i;
for(i=0;*(a+i)!='\0';i++)
{
if((*(a+i)>='a'&&*(a+i)<='z')||(*(a+i)>='A'&&*(a+i)<='Z'))
(*m)++;
else
(*n)++;
}
}
int main()
{
int *m,*n;
int count1=0,count2=0;
char a[N],b[N];
m=&count1;
n=&count2;
printf("str1:");
gets(a);
printf("str2:");
gets(b);
insert(a,b);
count(a,m,n);
printf("字符串拼接结果:");
puts(a);
printf("字母数量:%d\n",count1);
printf("非字母数量:%d\n",count2);
return 0;
}