《C语言程序设计》

下载本书

添加书签

C语言程序设计- 第11部分


按键盘上方向键 ← 或 → 可快速上下翻页,按键盘上的 Enter 键可回到本书目录页,按键盘上方向键 ↑ 可回到本页顶部!
蛴Π肺募╯tring。h〃。
下面介绍几个最常用的字符串函数。
1。  字符串输出函数 puts
   格式:  puts (字符数组名)
   功能:把字符数组中的字符串输出到显示器。 即在屏幕上显示该字符串。
【例7。12】
#include〃stdio。h〃
main()

  char c''〃BASICndBASE〃;
  puts(c);

从程序中可以看出puts函数中可以使用转义字符,因此输出结果成为两行。puts函数完全可以由printf函数取代。当需要按一定格式输出时,通常使用printf函数。
2。  字符串输入函数gets
   格式:  gets  (字符数组名)
   功能:从标准输入设备键盘上输入一个字符串。
本函数得到一个函数值,即为该字符数组的首地址。
【例7。13】
#include〃stdio。h〃
main()

  char st'15';
  printf(〃input string:n〃);
  gets(st);
  puts(st);

可以看出当输入的字符串中含有空格时,输出仍为全部字符串。说明gets函数并不以空格作为字符串输入结束的标志,而只以回车作为输入结束。这是与scanf函数不同的。
3。  字符串连接函数strcat
   格式:  strcat (字符数组名1,字符数组名2)
   功能:把字符数组2中的字符串连接到字符数组1 中字符串的后面,并删去字符串1后的串标志“0”。本函数返回值是字符数组1的首地址。
【例7。14】
#include〃string。h〃
main()

  static char st1'30'〃My name is 〃;
  int st2'10';
  printf(〃input your name:n〃);
  gets(st2);
  strcat(st1;st2);
  puts(st1);

本程序把初始化赋值的字符数组与动态赋值的字符串连接起来。要注意的是,字符数组1应定义足够的长度,否则不能全部装入被连接的字符串。
4。  字符串拷贝函数strcpy
   格式:  strcpy (字符数组名1,字符数组名2)
   功能:把字符数组2中的字符串拷贝到字符数组1中。串结束标志“0”也一同拷贝。字符数名2,也可以是一个字符串常量。这时相当于把一个字符串赋予一个字符数组。
【例7。15】
#include〃string。h〃
main()

  char st1'15';st2''〃C Language〃;
  strcpy(st1;st2);
  puts(st1);printf(〃n〃);

本函数要求字符数组1应有足够的长度,否则不能全部装入所拷
贝的字符串。
5。  字符串比较函数strcmp
   格式:  strcmp(字符数组名1,字符数组名2)
   功能:按照ASCII码顺序比较两个数组中的字符串,并由函数返回值返回比较结果。
字符串1=字符串2,返回值=0;
  字符串2〉字符串2,返回值〉0;
  字符串1〈字符串2,返回值〈0。
本函数也可用于比较两个字符串常量,或比较数组和字符串常量。
【例7。16】
#include〃string。h〃
main()
{ int k;
  static char st1'15';st2''〃C Language〃;
  printf(〃input a string:n〃);
  gets(st1);
  kstrcmp(st1;st2);
  if(k0) printf(〃st1st2n〃);
  if(k》0) printf(〃st1》st2n〃);
  if(kst2”。
6。  测字符串长度函数strlen
   格式:  strlen(字符数组名)
   功能:测字符串的实际长度(不含字符串结束标志‘0’) 并作为函数返回值。
【例7。17】
#include〃string。h〃
main()
{ int k;
  static char st''〃C language〃;
  kstrlen(st);
  printf(〃The lenth of the string is %dn〃;k);

7。4  程序举例
【例7。18】把一个整数按大小顺序插入已排好序的数组中。
为了把一个数按大小插入已排好序的数组中,应首先确定排序是从大到小还是从小到大进行的。设排序是从大到小进序的,则可把欲插入的数与数组中各数逐个比较,当找到第一个比插入数小的元素i时,该元素之前即为插入位置。然后从数组最后一个元素开始到该元素为止,逐个后移一个单元。最后把插入数赋予元素i即可。如果被插入数比所有的元素值都小则插入最后位置。
main()

  int i;j;p;q;s;n;a'11'{127;3;6;28;54;68;87;105;162;18};
  for(i0;i
小提示:按 回车 [Enter] 键 返回书目,按 ← 键 返回上一页, 按 → 键 进入下一页。 赞一下 添加书签加入书架