C语言程序设计(第3版)何钦铭 颜 晖 第11章 指针进阶
第11章 指针进阶
【练习11-1】如何理解指针数组,它与指针、数组有何关系?为何可以用二级指针数组进行操作?
解答:
指针数组——存放指针的一个数组。
指针数组名也是指向常量二级指针,因为指针数组名总是指向数组的第一个元素。
【练习11-2】用指针数组处理多个字符串有何优势?可以直接输入多个字符串给为初始化的指针数组吗?为什么?
解答:
C语言中字符串的地址是按顺序存放的,用指针指向字符串的首地址,然后取出这个地址里面的值,然后指针加一,取出里面的值,这样就能输出整个字符串了。用指针数组可以接收多个字符串,对这些字符串的操作可以做到相互隔离,一个指针数组的元素作为一个指针对应一个字符串。
【练习11-3】参考例11-3,使用二级指针操作改写例11-4中的程序A。
解答:
#include
#include
void fsort(char **ch,int n);
int main(void)
{
int i;
char *pcolor[]={"red","blue","yellow","green","black"};
char **ch;
ch=pcolor;
fsort(ch,5);
for(i=0;i<5;i++)
printf("%s ",*(ch+i));
return 0;
}
void fsort(char **ch,int n)
{
int k,j;
char *temp;
for(k=1;k
for(j=0;j
if(strcmp(*(ch+j),*(ch+j+1))>0){
temp=*(ch+j);
*(ch+j)=*(ch+j+1);
*(ch+j+1)=temp;
}
}
【练习11-4】改写例11-8中的函数match(),要求返回字符串s中最后一个字符ch的位置(地址)。
解答:
#include
char *match(char *s,char ch);
int main (void)
{
char ch,str[80],*p=NULL;
printf("Please Input the string:\n");
scanf("%s",str);
getchar();
ch=getchar();
if((p=match(str,ch))!=NULL)
printf("%s\n",p);
else
printf("Not Found\n");
return 0;
}
char *match(char *s,char ch)
{
char *k=NULL;
while(*s!='\0'){
if(*s==ch)
k=s;
s++;
}
return k;
}
【练习11-5】前面章节中介绍的指针变量都可以进行算数运算,请思考:指向函数的指针变量可以进行算术运算吗?
解答:
函数指针变量不能进行算术运算,这是与数组指针变量不同的。数组指针变量加减一个整数可使指针移动指向后面或前面的数组元素,而函数指针的移动是毫无意义的。??
【练习11-6】运行例11-10,试执行程序中个函数的功能,观察结果。
解答:
主函数包含选择链表新建、插入、删除和遍历的功能,而新建链表函数则是用链表的方式建立一整套有关学生的信息,插入操作函数则是可以在链表其中添加新的学生信息,删除操作函数则是可以在链表中删除要求删除的学生信息,最后的遍历操作函数则是显示所有的学生信息。
【练习11-7】改写例11-10中的函数DelectDoc(),要求删除链表中成绩小于60分的学生结点。
解答:
struct stud_node* DeleteDoc(struct stud_node *head,int score)
{
struct stud_node *ptr1,*ptr2;
/*要被删除结点为表头结点*/
while(head!=NULL&&head->score==score){
ptr2=head;
head=head->next;
free(ptr2);
}
if(head==NULL)
return NULL;
/*要被删除结点为非表头结点*/
ptr1=he