码迷,mamicode.com
首页 > 编程语言 > 详细

C语言博客作业--结构体

时间:2017-12-24 13:43:41      阅读:364      评论:0      收藏:0      [点我收藏+]

标签:work   提交   阶段   查询   mob   http   code   logs   返回   

一、PTA实验作业

函数题 题目1:结构体数组按总分排序

1.本题PTA提交列表

  • 技术分享图片

    2.设计思路

    void calc(struct student *p,int n)//计算每个人成绩总和的函数
    struct student *pos
    for pos=p to pos<p+n pos++
        pos->sum=pos->score[0]+pos->score[1]+pos->score[2]
    end for //计算每个人成绩的总和
    
    void sort(struct student *p,int n)
    struct student *min=p,temp;
    int i,j,index;
    for i=0 to i<n-1 i++
        index=i;
        for j=i+1 to j<n j++
            if(p[index].sum<min[j].sum)
                index=j;
            end for//运用选择排序法,查找每次循环中总成绩最大学生的下标
        temp=min[index];
        min[index]=p[i];
        p[i]=temp;
     end for//查找完之后,该下标的学生的全体信息与前面下标为i的学生的全体信息进行互换

3.代码截图

  • 技术分享图片

4.本题调试过程碰到问题及PTA提交列表情况说明

  • 问题:对选择排序法运用的还是不很熟练,最开始写选择排序的时候,在互换两结构成员信息的时候,自己粗心大意,技术分享图片
    让p[i]=min[index],应该让p[i]=temp,一直认为是循环的问题,检查了半天都没检查出来,最后通过调试,发现经过这个部分学生信息的互换并没有达到预期的目的,所以此处出现了错误
    技术分享图片

  • 解决方法:把p[i]=min[index]改为p[i]=temp,技术分享图片
    答案正确技术分享图片

    编程题--题目2.计算职工工资

    1.本题PTA提交列表

  • 技术分享图片

    2.设计思路

    struct worker{/*定义结构*/ 
    char name[10
    float zbpay;
    float fdpay;
    float zc;
    float sfpay;
    };//该结构体表示员工的姓名,基本工资,浮动工资,支出,实发工资
    int N,i,j;
    scanf("%d",&N);
    struct worker workers[N];//定义结构体数组
    for i=0 to i<N i++
        scanf("%s%f%f%f",workers[i].name,&workers[i].zbpay,&workers[i].fdpay,&workers[i].zc);
        workers[i].sfpay=workers[i].zbpay+workers[i].fdpay-workers[i].zc;
    end for//实现员工信息的输入,并计算实发工资
    for j=0 to j<N j++)
        printf("%s %.2f\n",workers[j].name,workers[j].sfpay)
    end for//输出每个员工的姓名和实发工资

    3.代码截图

  • 技术分享图片

4.本题调试过程碰到问题及PTA提交列表情况说明

  • 问题:定义的数组被越界了,技术分享图片
    一开始定义的结构体数组为技术分享图片
  • 解决方法:首先我认为,一般的段错误大部分是数组越界的问题,所以我让输入的N作为结构体数组的数组长度,这样不管N多大都不会越界了,技术分享图片

编程题--题目3. 通讯录的录入与显示

1.本题PTA提交列表

  • 技术分享图片

2.设计思路

    struct imformation{
    char name[20];
    char birthday[20];
    char sex[2];
    char imphone[19];/*im为固定英文immobilization的头两个字母*/
    char mophone[19];/*mo为移动英文mobile的头两个字母*/ 
    };//该结构体表示朋友的名字,出生日期,性别,固定电话,手机
        int N,i,n,j,k;
    scanf("%d",&N);
    struct imformation friends[N];//定义结构体数组,数组长度为N,避免段错误
    for i=0 to i<N i++)
        scanf("%s%s%s%s%s",friends[i].name,friends[i].birthday,friends[i].sex,friends[i].imphone,friends[i].mophone);
    end for//输入结构体数组每个朋友的信息
    scanf("%d",&n);//输入查询次数
    int number[n];//定义一个普通数组
    for j=0 to j<n j++)
        scanf("%d",&number[j])
        end for ;//把要查询的编号存入普通数组
    for i=0 to i<n i++
            if(number[i]>=0&&number[i]<N) printf("%s %s %s %s %s\n",friends[number[i]].name,friends[number[i]].imphone,friends[number[i]].mophone,friends[number[i]].sex,friends[number[i]].birthday);
            else printf("Not Found\n");
    end for// 遍历普通数组,如果数组的元素(就是编号)在0到N-1之内则输出 ,否则输出Not Found
    

3.代码截图

  • 技术分享图片

4.本题调试过程碰到问题及PTA提交列表情况说明

  • 问题:最开始定义结构体是这样的:技术分享图片
    年月日是整型,所以输入的时候技术分享图片在年月日之间通过加上‘/‘实现输入,输出的时候
    技术分享图片通过加上‘/‘实现输出,虽然答案正确但是这样的答案并不是PTA想要的
  • 解决方法:技术分享图片,年月日与‘/’通过字符串输入,再通过字符串方式输出,发现答案正确,可能PTA就是想让‘/’与年月日一起输入输出,而不是通过在输入与输出语句中打出‘/’的方式,而‘/’为字符,所以也就需要把年月日定义为字符型,因此字符串是最好的选择。

    二、截图本周题目集的PTA最后排名

  • 技术分享图片

三、阅读代码

四、本周学习总结

1.总结本周学习内容

1.1 结构体、共用体、枚举这种构造数据类型特点

  • 结构体:结构体和数组一样都是构造型数据类型,和数组不同的是,结构体可以处理不同类型的数据,结构体里还可以有结构体类型、共用体的类型的数据。
  • 共用体:共用体是一种多变量共享存储空间的构造类型,它允许几种不同的变量共用同一存储空间,共用体空间等于最大成员占据的空间且共用体不能赋初值。
  • 枚举:枚举类型是指变量的值可以全部列出,定义一个枚举变量后,变量的值确定在定义之中。枚举元素的类型是常量,只能在定义阶段赋值。

    1.2递归函数原理

  • 即函数自己不断的调用自己,任何递归函数都必须包含条件,来判断是否要递归下去,即要有递归出口与递归调用式子,一旦结束条件成立,递归克隆应该不再继续,以递归出口值作为函数结果,然后返回,结束一个递归克隆函数体。
    最后通过一层层的返回,一层层的计算出值,得到最终答案。其实质是把问题简化成形式相同,但较简单一些的情况,程序中每经过一次递归,问题就得到一步简化,不断地简化下去,最终归结到一个初始值,就不必再往下递了,最后就是一层一层的归了

    2.罗列本周一些错题

  • 2.1技术分享图片

    分析: 这一题中,题目要求把a中地址作为函数值返回主函数 所以第4个空格填p,而返回值必须与自定义函数的类型相同,由此可见,自定义的函数类型与p相同是指针
    错因:粗心,没有考虑到函数返回值需要和函数的类型相同,所以应填struct student *。


  • 2.2技术分享图片

    分析:这题递归函数的问题,需要确定正确的递归出口和递归式子,而我没有确定正确的递归出口
    错因:没有考虑到0!=1,所以应填n==0||n==1

C语言博客作业--结构体

标签:work   提交   阶段   查询   mob   http   code   logs   返回   

原文地址:http://www.cnblogs.com/wlgczjw/p/8097639.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!