函数嵌套调用

一、实验作业(5分)

1.1 PTA题目 递归法对任意10个数据按降序排序

设计思路
void sort(int a[],int n){
如果从主函数传进来的是1 直接退出
定义min=2147483647存放最小值,定义i=10-n,temp,t;
for i=0 to i=9 {
如果a[i]>=0{
if(a[i]<min){
min=a[i];
t=i;}}}
交换第10-n个数和剩下的最大数:
temp=a[10-n];
a[10-n]=min;
a[t]=temp;
sort(a,n-1);
}
end for
代码截图

调试问题
在写的时候运行出现只有第一个放了,后将a[0]换成a[10-n]就全换了

1.2 学生成绩管理系统

1.2.1 画函数模块图,简要介绍函数功能:

1.2.2 截图展示你的工程文件:

1.2.3 函数代码部分截图

1.2.3 函数代码部分截图

本系统代码总行数:285
要求截图你的头文件、插入学生信息及学生成绩信息代码、删除学生成绩信息代码、总分排序代码。
代码中务必加入必要的注释。




1.2.4 调试结果展示

要求分别展示菜单、每个命令运行结果,对非法数据必须有检验并提示,如用户学号输入非法、或者输入重复学号,提示插入失败。查询不到相应学生信息给予提示等等。
测试样例越多,分值越高
要求截图你的头文件、插入学生信息及学生成绩信息代码、删除学生成绩信息代码、总分排序代码。

未输入成绩输出:
正确输入:
排序:

代码中务必加入必要的注释。

二、截图本周题目集的PTA最后排名。(2分)

三、阅读代码(2分)

char * strcat(char *s, const char *append)
{
//将s所指向的字符串的首地址保存下来,以便使用
char *save = s;

    //将s所指向的字符串的首指针移至串尾处,s指针指向的字符元素为'\0'  
    for (; *s; ++s);  
  
    //将append所指的字符串的元素复制到s所指向的字符串尾部,直至遇到'\0'  
    while ((*s++ = *append++) != '\0');  
      
    //返回追加后的字符串首地址  
    return(save);  

}
这是OpenBSD对strcat的源代码,本函数的重点是将s所指向的字符串的首指针移至串尾处,十分巧妙。

四、本周学习总结(1分)

1.总结本周学习内容。

1.1 链表是什么?

链表是一种物理存储单元上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的。

1.2 链表由什么组成

链表由一系列结点组成

1.3递归函数

就是反复调用自己 直到找到出口的函数

2.罗列本周一些错题。

2.1

错选C 答案D 错误原因:看错

2.2

错选B 答案A 按照B选项修改后可能导致文件编译不过

posted @ 2017-12-31 22:41  林怡鹏  阅读(2596)  评论(1编辑  收藏  举报