第十一章编程练习
这一章的题目数量还是蛮多的,下面我们一个个的来看一下。
第一题让我们设计一个函数,从输入中获取n个字符,包括空白、制表符以及换行符,所以像gets、fgets这种舍弃空白或者换行符的函数就先不用了,因为是获取字符,我们用getchar函数去获取,我不太理解这个函数的具体目的,所以按照自己的理解对其进行实现的,详细代码以及运行结果如下:
#include<stdio.h>
#define N 20
void get_c(char * arr, int n);
int main(){
char arr[N];
printf("请输入%d个字符:\n",N);
get_c(arr,N);
for (int i = 0; i < N; i++){
putchar(arr[i]);
}
printf("\nDone!!!");
getchar();
return 0;
}
void get_c(char * arr, int n){
char c;
for (int i = 0; i < n; i++){
c = getchar();
*(arr + i) = c;
}
}
接下来,第二题让我们对练习一的函数进行修改,在n个字符之后停止,或者在读到第一个空白、制表符或者换行符时停止,还不能使用scanf,分析一下,应该是让我们使用fgets函数。程序的完整代码以及运行结果如下:
#include<stdio.h>
#define N 20
void get_c(char * arr, int n);
int main(){
char arr[N];
printf("请输入字符:\n");
get_c(arr,N);
fputs(arr,stdout);
printf("\nDone!!!");
getchar();
return 0;
}
void get_c(char * arr, int n){
fgets(arr,n,stdin);
}
接着我们来看第三题,要将一个单词存入一个数组中,丢弃掉其余字符,明显使用scanf函数,完整程序代码以及运行结果如下:
#include<stdio.h>
#define N 20
void get_c(char * arr, int n);
int main(){
char arr[N];
printf("请输入字符:\n");
get_c(arr,N);
printf("%s",arr);
printf("\nDone!!!");
getchar();
return 0;
}
void get_c(char * arr, int n){
scanf("%s",arr);
}
第四题要在第三题的基础上加一个限制读取字符数的函数。虽然在转换说明中添加数字可以限制长度,但是因为参数n是变化的,所以我们用getchar对其进行实现,完整程序代码以及运行结果如下:
#include<stdio.h>
#include<ctype.h>
#define N 20
void get_c(char * arr, int n);
int main(){
char arr[N];
printf("请输入字符:\n");
get_c(arr,N);
printf("%s",arr);
printf("\nDone!!!");
getchar();
return 0;
}
void get_c(char * arr, int n){
int i,j = 0;
char ch;
while (ch = getchar()){
if (isspace(ch)&&j==0){
continue;
}else if(!isspace(ch)&&j==0){
j = 1;
*(arr + i) = ch;
i++;
}else if(!isspace(ch)&&j==1){
*(arr + i) = ch;
i++;
}else if(isspace(ch)&&j==1){
break;
}
}
}
接着,我们来看第五题,写一个与strchr功能差不多的函数,获取两个参数,返回首次出现的地址。完整程序代码以及运行结果如下:
#include<stdio.h>
#include<string.h>
#define STR "I am the king of su."
char * get_wz(char * arr, char ch);
int main(){
char c;
printf("请输入需要查找的字符:\n");
scanf("%c",&c);
char * wz = get_wz(STR, c);
printf("该字符在字符串中首次出现在第%d个位置\n", (wz-STR+1));
printf("该字符在字符串中首次出现的地址为:%p", wz);
printf("\nDone!!!");
getchar();
return 0;
}
char * get_wz(char * arr, char ch){
int n = strlen(arr);
char * r;
for (int i = 0; i < n; i++){
if (*(arr + i) == ch){
r = arr + i;
break;
}else{
r = NULL;
continue;
}
}
return r;
}
下面,来看一下第六题的内容,去判断一个字符是否存在于一个字符串之中,用一个函数去判断。也不复杂,完整程序代码以及运行结果如下:
#include<stdio.h>
#include<string.h>
#define STR "I am the king of su."
int get_wz(char * arr, char ch)