指针数组,还是向数组的指针?
由于方括号[]的优先级要高于*号,所以
char *m[5]表示一个由五个指针构成的数组。
而
(char *)m[5]表示一个指针,一个指向有五个元素的数组的指针。
数组和指针的区别
char m1[]="abcdefg";
char m2*="abcdefg"
- m1是一个常量,是不能执行m1++的,但是可以通过m1+1来访问m1的第二个元素。
- 而m2是个变量,可以进行m2++。
- m1的值可以赋给m2,但是m2的值不能赋给m1
二维数组和指针数组的区别
char a1[5][81];
char *a2[5]
a1是一个有5个元素的数组,而每个元素又是一个81个char的数组,所以声明a1的时候,就为之声明了5*81个char的空间。
a2是一个含有5个指针的数组,每个指针指向一个字符串,字符串所占用的空间可由初始化字符串时的字符串长度决定。
所以,第二种声明方式比第一种声明方式比较节省空间。
三个输入函数的区别
gets()遇到换行符就会停止输入,它适合用来读取一行字符串。返回一个指向char类型的指针值。
scanf()遇到空格就会停止输入,所以它适合用来读取单词。返回成功读取项目的个数。
fgets()既能读空格又能读换行符,它有三个参数,fget(指针的地址,读入的长度,输入文件),当通过键盘输入时,第三个参数为stdin。
当读到第二个参数的长度或者换行符时,停止读取。
常用的字符串函数
函数都包含在string.h头文件里
strcat()函数
strcat()函数需要两个字符串参数,将第二个字符串的一份拷贝添加到第一个字符串的结尾。从而连接了两个字符串。返回值是第一个参数更新后的值。
strncat()函数
strncat(char * c1,char * c2,int n);
后面的n为读c2的前n个字符,读到第n个字符或者遇到换行符都会停止读取,然后将读取到的字符接到c1的末尾
strcmp()函数
strcmp(cha * c1,char * c2);
顾名思义,string compare,比较c1和c2,
如果c1c完全相同,则返回0。
如果不同,比较第一个c1c2不同的字符,如果c2中的字符的ASCII值大于c1中的字符的ASCII值,返回1,否则,返回-1。
strncmp()函数
strcmp(cha * c1,char * c2,n);
比较c1c1的前n个字符,返回结果与strcmp()函数相同.
strcpy()函数
有两个字符串参数,将第二个字符串参数复制到第一个字符串参数,返回第一个参数的值。
由于字符串的名字只是一个地址,所以在初始化字符串之后就不能再给字符串复制,像这样“str="abcde"
只能strcpy(str,"abcde")”
strchr()函数
char *strchr(const char *s,int c);
返回字符串中存放字符c的第一个位置的指针,如果没有找到该字符,就返回空指针。
//strchr函数
#include<stdio.h>
#include<string.h>
int main()
{
char *a="abcdefg";//声明一个指针,
char c='e';
char *b;//用来存放返回的指针
b=strchr(a,c);
printf("%p %p\n",a,b);//输出的结果是两个相差4的地址,因为e字符数组里的第4个元素。
b=strchr(a,'z');
printf("%p %p\n",a,b);//输出的b是8个0的空指针
return 0;
}
strpbrk(const char *s1,const char *s2)函数
返回一个指针,指向s1字符串中存放s2中任一字符串的地方,如果找不到,则返回空指针
#include<stdio.h>
#include<string.h>
int main()
{
char *s1="abcdefg";
char *s2="efghijk";//s1和s2中第一个共同的元素是e
char *a;
a=strpbrk(s1,s2);
printf("%p %p %d\n",s1,a,a-s1+1);//第一个地址和第二个地址相差4,e是s1中的第5个元素
return 0;
}
strrchr(const char *s,int c)
和strchr()类似,不过他返回的是最后一次出现c的地方
字符串排序
原理是冒泡排序加strcmp函数的调用。并不难。
#include<stdio.h>
#include<string.h>
#define SIZE 81
#define LIM 20
#define HALT " "
void stsrt(char *strings[],int num);
int main()
{
char input[LIM][SIZE];
char *ptstr[LIM];
int ct = 0;
int k;
printf("Input up to %d lines, and I will sort them.\n",LIM);
printf("To stop, press the Enter key at a line's start. \n");
while(ct < LIM && gets(input[ct]) != NULL && input[ct][0] != '\0')
{
ptstr[ct] = input[ct];
ct++;
}
stsrt(ptstr, ct);
puts ("\nHere's the sorted list: \n");
for(k = 0;k < ct; k++)
puts(ptstr[k]);
return 0;
}
void stsrt(char *strings[],int num)
{
char *temp;
int top,seek;
for(top = 0; top < num-1; top++)
for(seek = top + 1; seek < num ; seek++)
if(strcmp(strings[top], strings[seek]) > 0)
{
temp = strings[top];
strings[top] = strings [seek];
strings[seek] = temp;
}
}