zoukankan      html  css  js  c++  java
  • 结构体和共用体

    c程序实验报告

    姓名:熊承启   实验地点:教学楼514教室    实验时间:6月23

    一、本章要点

    1.通过实验理解结构体和共用体的数据结构
    2.结构体、共用体中数组的使用及变量的赋值
    3.结构体和共用体定义时的嵌套使用(嵌套使用的结构体必须先定义)

    二、实验内容

    1.实验练习:9.1

    问题描述:试利用结构体类型描述年、月、日,输入一个日期,统计该日期是本年度第多少天。

    流程图

    实验代码

    #include<stdio.h>
    main()
    {
        struct date
        {int year;
         int month;
         int day;
        };
        struct date a;
        int i,days;
        printf("输入年,月,日:");
        scanf("%d%d%d",&a.year,&a.month,&a.day);
        for(i=1;i<a.month;i++)
        {
            if (i==1||i==3||i==5||i==7||i==8||i==10)
            {days+=31;}
            else if(i==4||i==6||i==9||i==11)
            {days+=30; }
            else if(a.year%400==0||(a.year%4==0&&a.year %100!=0))
            {days+=29;}
            else
       {days+=28;} 
        }
              days+=a.day-1;
            printf("%d年%d月%d日是该年的第%d天",a.year,a.month,a.day,days);        
    }
    

     运行结果:

    问题分析:1.在判断闰年的时候我用的是year去相余,正确的是用a.year去相余。

              2.最后天数的总和的表达式有多种,因为会导致重复一天,可以把减一放在days的表达式上也可以放进printf()里面。

    2、结构体数组的应用

    问题的简单描述:在选举中,假设有6位候选人,有10个人参加投票(只能对一位候选人投票),用结构体数组统计各候选人的得票数。算法描述如图:

    流程图:

    实验代码:

    #include<stdio.h>
    #include<string.h>
    struct person
    { char name[20];
      int count;
    }a[6]={"zhang",0,"li",0,"wang",0,"zhao",0,"liu",0,"zhu",0};
     main()
    {
        int i,j;char abc[20];
        for(i=1;i<=10;i++)
        {
            printf("输入候选人名字:");
            scanf("%s",&abc[i]);
        for(j=0;j<6;j++)
            if(strcmp(a[j].name,&abc[i])==0)
            a[j].count+=1; 
        }
        for(j=0;j<6;j++)
        printf("%s:%d
    ",a[j].name,a[j].count);}
    

    运行结果:

     问题分析:1.字符串的结构体,要用到“strcmp(a[j].name,abc)”才能正常编译

    3.实验练习:9.3

    问题描述:

    编写程序填写表格,从键盘输入学生和教师的信息,若是学生,则班级/职称栏填入班级;若是教师,则班级/职称栏填入职称。

    流程图

    实验代码:

    #include <stdio.h>
    #include <stdlib.h>
    struct 
    {
        int number;
        char name[30];
        char job;
        union
        {
            int classes;
            char position[10];
        }category;
    }person[2];
    main()
    {
        int i;
        for(i=0;i<2;i++)
        {
            printf("请输入相应的编号,姓名,职业:"); 
            scanf("%d%s%s",&person[i].number,&person[i].name,&person[i].job);
            if(person[i].job=='s')
            {
            printf("请输入相应的班级/职务:");
            scanf("%d",&person[i].category.classes);
            }
     else if(person[i].job=='t')
        {
            printf("请输入相应的班级/职务:");
            scanf("%s",&person[i].category.position);
        }
            else
            {
                printf("input error!");
                abort();
             } 
         } 
         printf("
    ");
         printf("编号		姓名		职业		班级/职务
    ");
         for(i=0;i<2;i++)
         if(person[i].job=='s')
         printf("%d		%s		%c		%d
    ",person[i].number,person[i].name,person[i].job,person[i].category.classes);
         else
         printf("%d		%s		%c		%s
    ",person[i].number,person[i].name,person[i].job,person[i].category.position);
     } 
    

      

    运行结果:

    问题分析:1.fflush(stdin);的作用用来清除缓存区,采用这个就能在两次循环后跳出了。

                      2.在最后for()循环控制输出时,数据类型是不一样的,将它通化了。

                      3.在对数组的头文件的格式不是很清楚,像person.[i]name可以作为头文件而不用回址符‘&’并不清楚。

    4.实验练习:9.4

    问题描述:

    n个人围成一圈,从第s个人开始按顺时针1,2,3,……,m的顺序报数,数到m的人出圈,然后从出圈的下一个人开始重复此过程,输出所有出圈人的顺序。n,s,m从键盘输入。

    流程图

    实验代码:

    #include<stdio.h>
    #define N 10
    struct child
    {
        int no;
        int next;
    };
    struct child link[30];
    main()
    {
        int i,n,m,s,count,h;
        printf("输入围圈人数:出圈报数,开始报数位置:");
        scanf("%d%d%d",&n,&m,&s);
        for (i=1;i<=n;i++)
        {
            if(i==n)
            link[i].next=1;
            else
            link[i].next=i+1;
            link[i].no=i;
        }
        count=0;
        if(s==1)h=n;else h=s-1;
        printf("出圈顺序为:");
        while(count<n-1)
        {
            i=0;
            while(i!=m)
            {
                h=link[h].next;
                if(link[h].no) 
                i++;
            }
            printf("%d,",link[h].no);
            link[h].no=0;
            count++;
         } 
         for(i=1;i<=n;i++)
         if(link[i].no!=0)
         printf("%d",link[i].no);
    }
    

      

    运行结果:

    问题分析:1.围圈人数和出圈顺序的变量容易混淆导致在输出上出现错误。

    三、实验小结

    1.结构体中数组变量的输入可以不使用‘&’取地址运算符。
    2.结构体中函数定义的嵌套使用,在输出的时候要明确好结构体名字逐级输入。
    3.结构体名称为数组时,与for循环一起使用要精确到结构体中的每项变量。

    4.进行比较的时候用strcmp函数,退出程序用abort函数

             

  • 相关阅读:
    faked 一个用于 mock 后端 API 的轻量工具
    分享开源 Markdown 编辑器 Mditor 的「桌面版」
    一个 MVC 框架以 MVVM 之「魂」复活了!
    简单的内存缓存模块
    Node 多进程并发控制小模块
    Confman
    用 Nokitjs 解决前端开发中的跨域问题
    LEK分布式日志系统搭建
    hello world2
    hello world!
  • 原文地址:https://www.cnblogs.com/xiongchengqi/p/11110132.html
Copyright © 2011-2022 走看看