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

    C程序设计实验报告

    实验练习:
    9.3.1、结构体变量的应用

    9.3.2、结构提数组的应用

    9.3.3、共用体的应用

    9.3.4、结构提指针的应用

    姓名:邹慧莹 实验地点:教学楼514教室 实验时间:6月26日

    一、本章要点

    9.3.1、结构体变量的应用

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

    9.3.2、结构提数组的应用

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

    9.3.3、共用体的应用

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

    9.3.4、结构提指针的应用

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

    二、实验内容

    9.3.1、结构体变量的应用

    • 问题的简单描述:试利用结构体类型描述年、月、日,输入一个日期,统计该日期是本年度第几天。算法描述如图所示:
    • 实验代码:
    #include<stdio.h>
    main()
    {
    	struct date
    	{
    		int year;int month;int day;
    	};
    		struct date 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);
     } 
    
    • 实验结果:
    • 问题分析:
      1.结构体类型的定义可放在函数体内或函数体外
      2.结构体变量在被用时,要用结构体名.变量名的形式
      3.当i=1,3,5,7,8,9时,函数输出结果为

      试了一月二月份都对的上,到了三月以后就会多两天,说明并没有把二月当做28,或29来算,而是直接当做31天,所以不能作为整体输出,应该分别输入。

    9.3.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);
      	for(j=0;j<6;j++)
      	   if(strcmp(abc,a[j].name)==0)  a[j].count++;
      }
      for (j=0;j<6;j++)
           printf("%s:%d
    ",a[j].name,a[j].count);
    }
    
    • 实验结果:
    • 问题分析:
      1.scanf中引用变量,引用数组的时候不要寻址符&
      2.比较函数strcmp(str1,str2),若str1=str2,则返回零;若str1<str2,则返回负数;若str1>str2,则返回正数。

    9.3.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.调用abort()函数退出程序
      2.制作表格用 来输出,否者就会出现不对齐

    9.3.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[N];
    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);
    }
    
    • 实验结果:
    • 问题分析:定义数组link[N],N可以定义稍微大些,但n比N小

    三、实验小结

    1.数组引用的时候不用寻址符,因为表示首地址
    2.不能将记录作为一个 整体输出,而应分别输出
    3.进行比较的时候用strcmp函数,退出程序用abort函数

  • 相关阅读:
    面试题目小结
    面试题目3
    C#中new和override区别
    [转]:存储过程与函数的区别
    [转载]:C# 面试题大全
    [转]:C++虚函数表解析
    【修订版】C#/ASP.Net 面试题及答案(1)
    [转载]:C# 中结构与类的区别
    [转载]:C#笔试题面试题锦集
    [转载]:SQL Server性能调优之执行计划深度剖析 第一节 浅析SQL执行的过程
  • 原文地址:https://www.cnblogs.com/zzzdka/p/11109150.html
Copyright © 2011-2022 走看看