zoukankan      html  css  js  c++  java
  • 第九章 结构体与共用体

    C程序设计实验报告

    实验项目:

    1、结构体变量的应用
    2、结构体数组的应用
    3、共用体的应用
    4、结构体指针的应用

    姓名:杨婷  实验地点:514教室  实验时间:2019.6.26

    一、本章要点

    1、定义结构体类型的变量,要从键盘输入初值;
    2、输入错误时,调用abort()函数退出程序,要包含头文件stdlib.h;
    3、调用strcmp()函数进行字符串的比较;
    4、结构体类型为构造数据类型时,应先定义类型,然后再定义该类型的变量;
    5、结构类型的定义可以嵌套,结构类型与联合类型的定义也可以嵌套,只是要注意被嵌套的类型必须先有定义。

    二、实验目的与要求

    9.3.1 结构体变量的应用
    1、定义结构体类型struct date,它含有年、月、日3个成员;
    2、定义struct date类型的变量,并从键盘输入初值;
    3、利用循环语句,计算天数;
    4、利用分支结构,判断闰年。

    9.3.2 结构体数组的应用
    1、定义候选人struct person结构体数组,含有姓名、得票数两个成员;
    2、定义struct person结构体数组,人数自定,初始票数为0;
    3、利用循环输入候选人名字,该人员票数加1;
    4、输入的候选人不是规定的候选人时,相当于废票,不累计。

    9.3.3 共用体的应用
    1、定义结构体类型,其成员有编号、姓名、职业和班级(或职务);
    2、定义该结构体类型的数组,可有若干个数组元素;
    3、利用该循环语句输入每条记录的数据,若该记录的职业为‘s’,则该记录是学生,输入该学生的班级;若该记录的职业是’t‘,则该记录是教师的,输入该教师的职务;
    4、根据记录的职业来判断,使用哪个printf()语句输出记录。

    9.3.4 结构体指针的应用
    1、定义结构体类型,其成员有人员编号、下一人员编号(地址);
    2、定义该结构体类型的数组,可有n个数组元素;
    3、n个人围成一圈,可以考虑用结构体数组元素中的“下一人员编号”来实现,但最后一个元素的“下一人员编号”指向第一个。

    三、实验内容

    1、结构体变量的应用
    <1>问题的简单描述:
    试利用结构体类型描述年、月、日,输入一个日期,统计日期是本年度第多少天。
    算法描述如图:

    <2>实验代码:

    #include<stdio.h>
    main()
    {
    	struct date
    	{ 
    		int year;int month;int day;  /*含有年、月、日三个成员*/
    	};
    		struct date a;  /*定义结构体变量a*/
    		int i,days=0;  /*定义其他变量*/
         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%4==0&&a.year%100!=0)||a.year%400==0) 
    		 days+=29;
    		else days+=28; 
    			 }		
    			 days+=a.day;
    			 printf("%d年%d月%d日是该年的第%d天",a.year,a.month,a.day,days);
     }   /*输出结果*/
    

    <3>运行结果:

    <4>问题分析:
    问题:

    解决方法:
    检查了几遍我的代码之后,发现“逻辑与”我只打了一个“&”,还有在判断闰年的表达式中我将取余符号打成了寻址符。
    2、结构体数组的应用
    <1>问题的简单描述:
    在选举中,假设有6位候选人,有10个人参加投票(只能对一位候选人投票),用结构体数组统计各候选人的得票数。
    算法描述如图:

    <2>实验代码:

    #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);  /*输入候选人名字*/
      	for(j=0;j<6;j++)
      	   if(strcmp(abc,a[j].name)==0)  a[j].count++;
            /*若第j个候选人名字与输入的名字相同,第j位候选人票数加1*/
      }
      for (j=0;j<6;j++)
           printf("%s:%d
    ",a[j].name,a[j].count);  /*输出各候选人的名字和得票数*/
    }
    

    <3>运行结果:

    <4>问题分析:
    问题:

    输入完第一个候选人名字后,后面所有的“候选人名字”都出来了。
    解决方法:
    检查了代码之后发现在最后的printf()函数中输入的应该是a[j].name,而不是a[i].name。
    3、共用体的应用
    <1>问题的简单描述:
    编写程序填写表格。从键盘输入学生和教师的信息,若是学生,则班级/职务栏填入班级;若是教师,则班级/职务栏填入职称。
    算法描述如图:

    <2>实验代码:

    #include<stdio.h>
    #include<stdlib.h>  /*包含头文件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		",person[i].number);
                    printf("%s		",person[i].name);
                    printf("%c		",person[i].job);
                    printf("%d
    ",person[i].category.classes);  /*输出学生的记录*/
                }
            else
                {
                    printf("%d		",person[i].number);
                    printf("%s		",person[i].name);
                    printf("%c		",person[i].job);
                    printf("%s
    ",person[i].category.position);     
                }
        }
    }
    

    <3>运行结果:

    <4>问题分析:
    问题:

    解决方法:
    我按照书上的示例依次输入了姓名、编号、职业和职务,但实际上输入的顺序应该是编号、姓名、职业。
    4.结构体指针的运用
    <1>问题的简单描述:
    n个人围成一圈,从第s个人开始按顺时钟1,2,3.....,m的顺序报数,数到m的人出圈,然后从出圈的下一个人开始重复此过程,输入所有出圈人的顺序。n,s,m从键盘输入。
    算法描述如图:

    <2>实验代码:

    #include<stdio.h>
    #define N 10  /**最多围圈人数/
    struct child
    {
        int no;  /*人员编号*/
        int next;  /*下一人员编号*/
    };
    struct child link[N];  /*定义结构体数组link[N],描述所有人员*/
    main()
    {
        int i,n,m,s,count,h;   /*定义变量*/
        printf("输入围圈人数,出圈报数,开始报数位置:");  
        scanf("%d%d%d",&n,&m,&s);
       /*输入围圈人数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)   /*出圈人数<围圈人数-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);   /*输出最后留在圈中人数*/
    
        }
    }
    

    <3>运行结果:

    <4>问题分析:
    输出最后留在圈中人数时要用“link[i].name”。

    四、实验小结

    收获:
    1.当输入错误时,调用abort()函数退出程序(void abort(void));
    2.比较候选人的名字:strcmp(abc,a[j].name)==0;
    (用比较运算符对两个枚举型变量或数组元素进行“大小”比较,可以按照变量或数组元素的枚举变量值(整数)的大小进行比较);
    3.逻辑与要打两个取址符。
    不足:
    1.在打代码过程不够仔细,会打错一些符号;
    2.总是按照书上的内容来做,但有时候书上的内容也会出错。

  • 相关阅读:
    JAVA线程池
    数据库三范式和反三范式
    nvm切换node的版本
    vue源码解析一
    css实现气泡样式
    openlayer 地图实现圈选框选清楚 选择地图区域
    vs code开发常用插件
    记录几个好用的工具
    03 使用css改变页面样式
    02 常用的html元素
  • 原文地址:https://www.cnblogs.com/youthyee/p/11108738.html
Copyright © 2011-2022 走看看