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