C Primer Plus 第六版---编程练习11

1.设计并测试一个函数,从输入中获取下n个字符(包括空白、制表符、换行符),把结果储存在一个数组里,它的地址被传递作为一个参数。

#include<stdio.h>
#define LEN 80

char *getch(char a[], int n);
int main(void)
{
	char a[LEN];
	if (getch(a, 4))
		puts(a);
	else
		printf("没有读取\n");
	return 0;
}
char* getch(char a[], int n)
{
	int i;
	for (i = 0; i < n; i++)
	{
		a[i] = getchar();
		if (EOF == a[i])
		{
			a[i] = '\0';
			break;
		}
	}
	a[i] = '\0';
	if (!a[0])
		return a;
}

2.修改并编程练习1的函数,在n个字符后停止,或在读到第1个空白、制表符或换行符时停止,哪个先遇到哪个停止。不能只使用scanf()。

#include<stdio.h>
#include<ctype.h>

#define LEN 80

char * getch(char a[], int n);
int main()
{
	char a[LEN];
	if (getch(a, 6))
		puts(a);
	else
		printf("没有读取\n");
	return 0;
}
char* getch(char a[], int n)
{
	int i;
	for (i = 0; i < n; i++)
	{
		a[i] = getchar();
		if (EOF == a[i] || isspace(a[i]))
		{
			a[i] = '\0';
			break;
		}
	}
	a[i] = '\0';
	if ('\0' == a[0])
		return NULL;
	return a;
}

3.设计并测试一个函数,从一行输入中把一个单词读入一个数组中,并丢弃输入行中的其余字符。该函数应该跳过第1个非空白字符前面的所有空白。将一个单词定义为没有空白、制表符或换行符的字符序列。

#include<stdio.h>
#include<ctype.h>
#include<stdbool.h>  

bool getword(char*);
int main(void)
{
	char array[20];
	if (getword(array))
		puts(array);
	else
		puts("没有读取到单词");
	return 0;
}
bool getword(char* array)
{
	char ch;
	int a = 0;
	char *p = array;
	while ((ch = getchar()) != '\n')
	{
		if (a == 0 && isspace(ch))
			continue;
		else
			a = 1;
		if (!isspace(ch))
			*array++ = ch;
		else
			break;
	}
	*array = '\0';
	if (*p == '\0')
		return false;
	return true;
}

4.设计并测试一个函数,它类似编程练习3的描述,只不过它接受第2个参数指明可读取的最大字符数。

#include<stdio.h>
#define LEN 80

char* search(char* str, char ch);  //声明

int main(void)
{
	char ch;
	char target[LEN];
	char * pstr;
	puts("请输入字符串(在一行的开始输入回车结束):");  //输出字符串
	while (gets(target) && target[0] != '\n')  //读取一行字符串,当第一个字符不为换行符时
	{
		puts("请输入字符:");
		ch = getchar();  //读取一个字符
		while (getchar() != '\n')  //当字符不为换行符时
			;  //
		pstr = search(target, ch);
		if (pstr == NULL)
			printf("字符%c不在字符串中\n", ch);
		else
			printf("找到字符%c,它的地址为%p\n", ch, pstr);
		puts("请输入下一个字符串(在一行的开始输入回车结束):");
	}
	return 0;
}
char* search(char* str, char ch)
{
	while (*str != '\0')  //指针变量不为\0即字符结尾进入比较判断
	{
		if (*str++ == ch)  //比较若相等返回str
			return str;
	}
	return NULL;  //字符结尾时返回NULL
}

5.设计并测试一个函数,搜索第1个函数形参指定的字符串,在其中查找第2个函数形参指定的字符首次出现的位置。如果成功,该函数返指向该字符的指针,如果在字符串中未找到指定字符,则返回空指针(该函数的功能与 strchr()函数相同)。在一个完整的程序中测试该函数,使用一个循环给函数提供输入值。

#include<stdio.h>
#include<stdlib.h>

char* find_ch(char* str, char ch);  //函数声明

int main()
{
	char ar[200];
	char ch;
	printf("请输入查找字符:\n");
	scanf("%c", &ch);  //读入字符
	while (getchar() != ar[0]) continue; //滤掉scanf的回车,因为puts遇到回车直接结束输入
	printf("请输入字符串:\n");
	gets(ar);
	while ('\0' != ar[0])
	{
		char * judge = find_ch(ar, ch);
		if (judge)
			puts(judge);
		else
			printf("none\n");
		printf("请输入字符串:\n");
		gets(ar);
	}
	printf("done!\n");
	return 0;
}
char * find_ch(char* str, char ch)
{
	while (*str != '\0' && *str != ch)
		str++;
	if(ch == *str)
		return str;
	if ('\0' == *str)
		return NULL;
}

6.编写一个名为is_within()的函数,接受一个字符和一个指向字符串的指针作为两个函数形参。如果指定字符在字符串中,该函数返回一个非零值(即为真)。否则,返回0(即为假)。在一个完整的程序中测试该函数,使用一个循环给函数提供输入值。

#include<stdio.h>
#include<stdlib.h>
int is_within(char ch, char* ptr
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值