2018C语言第二次作业

一、学习内容总结

1.指针是一种数据类型,同样占有空间,其存储的是内存地址;

2.定义指针变量要在变量名之前加“*”字符表示;

3.“&”是取地址运算符,“*”是间接运算符;

(注:声名和使用指针时*的意义不同)

4.指针的数据类型是指它所指向的内存空间的数据类型;

5.指针可以与整数进行加减运算,但只能与指针进行减法运算;

6.可以把指针声明成为指向函数的指针,从而通过函数指针调用函数;

7.数组的数组名(二维数组的列)可以看作一个指针;

8.为了防止野指针,一般将指针定义在其他变量之后或者指向NULL。

二、在课堂或课后编程学习遇到的问题及解决过程

  • 问题1:

课后作业“删除字符串中指定字符”的编程中,自定义函数的函数体内没有与调用时定义的变量保持一致导致编译程错误,即调用的地址变量虽然没有“*”标识,但是函数体内要用地址变量定义。(下为delchar的代码,我认为删除字符不应该是简单的过滤)

 1 #include<stdio.h>
 2 #include<stdlib.h>
 3 #include<string.h>
 4 void delchar(char *s,char c);
 5 int main()
 6 {
 7     char s[100],c;
 8     gets(s);
 9     getchar();
10     c=getchar();
11     delchar(s,c);
12     puts(s);
13     system("pause");
14     return 0;
15 }
16 void delchar(char *s,char c)
17 {
18     char *ss=NULL;
19     while(*s)
20     {
21         if(*s==c)
22         {
23             ss=s;
24             while(*s)
25             {
26                 *s=*(s+1);
27                 s++;
28             }
29             s=ss-1;
30         }
31         s++;
32     }
33 }

解决方案:如上代码,定义函数“void delchar(char *s,char c)”即可。

  • 问题2:

课后作业“从指定位置复制字符串”的编程中,开始没有考虑到题目输入中的位置其实对应字符串下标减一而导致答案错误。(下为正确代码)

 1 #include<stdio.h>
 2 #include<stdlib.h>
 3 #include<string.h>
 4 void strmcpy(char *s,char *t,int m);
 5 int main()
 6 {
 7     char t[100],s[100];
 8     int m;
 9     gets(t);
10     scanf("%d",&m);
11     strmcpy(s,t,m);
12     puts(s);
13     system("pause");
14     return 0;
15 }
16 void strmcpy(char *s,char *t,int m)
17 {
18     while(m--)
19     {
20         t++;
21     }
22     strcpy(s,t-1);   //本条自定义函数实质为strcpy(s,t+m-1);
23 }

解决方案:如上代码,在调用strcpy函数时在t后减一即可。

  • 问题3:

课后作业“二维数组冒泡排序”的编程中,直接照搬了从前一维数组冒泡排序的思路,从而忽视了二维数组多出来的一层边界的越界问题而导致一些情况下出现答案错误(如下图)。

解决方案:重新考虑了第二层边界的越界问题并修改了for循环的条件。

三、作业

1.PTA(指针字符串查找字符程序)

 1 #include<stdio.h>
 2 #include<string.h>
 3 int main()
 4 {
 5     int i,n=0,count=0;
 6     char a[80],x;
 7     while((a[n]=getchar())!='
')
 8         n++;
 9     x=getchar();
10     while(n--)
11         if(x==a[n])
12             count++;
13     printf("%d",count);
14     return 0;
15 }

(输出截图)

2.二维数组冒泡排序

 1 #include<stdio.h>
 2 #include<stdlib.h>
 3 #include<string.h>
 4 int main()
 5 {
 6     char a[5][80];
 7     char temp[80];
 8     int i,j;
 9     for(i=0;i<5;i++)
10     {
11         gets(a[i]);
12     }
13     printf("二维数组冒泡排序:
");
14     for(j=0;j<4;j++)
15     {
16         for(i=0;i<4-j;i++)
17         {
18             if(strcmp(a[i],a[i+1])>0)
19             {
20                 strcpy(temp,a[i]);
21                 strcpy(a[i],a[i+1]);
22                 strcpy(a[i+1],temp);
23             }
24         }
25     }
26     for(i=0;i<5;i++)
27     {
28         puts(a[i]);
29     }
30     system("pause");
31     return 0;
32 }

(输出截图)

四、中国大学MOOC

原文地址:https://www.cnblogs.com/cyq66992152/p/8735950.html