填空题(投票、结构体数组、指向结构体的指针)

第1关:程序填空(1)

#include <stdio.h>
#include <string.h>

struct  person
{
    char name[8];
    int count;
};

int main()
{

int i,j;
    char name[8];
    struct  person leader[5]={"zhang",0,"sun",0,"li",0,"yang",0,"zhao",0};

    for(i=1;i<=10;i++)
    {
        char n[8] = { 'a' };
        scanf("%s",n); 

    for(j=0;j<5;j++)
        if(strcmp(n,leader[j].name) == 0)
        leader[j].count+=1; 
           
    }
    
    printf("投票结果:\n");
    printf("姓名      票数\n");
    for(j=0;j<5;j++)

/***** 在以下一行填写代码 *****/
         printf("%-10s%d\n", leader[j].name,leader[j].count);     //输出各候选人的名字和票数
    return 0;
}

第2关:程序填空(2)

#include <stdio.h> 
typedef struct 
{
    char name[10]; 
    int age; 
}STD;

STD fun(STD std[], int n)
{

STD max; int i;
    
    /***** 在以下一行填写代码 *****/
    max=       (1)       ;
    

    for(i=1; i<n; i++)
        
    /***** 在以下一行填写代码 *****/
    if(max.age<    (2)        )
        max=std[i];

return max;
}
int main( )
{
    STD std[5]={"aaa",17,"bbb",16,"ccc",18,"ddd",17,"eee",15 };
    STD max;
    max=fun(std,5);
    printf("The result:\n");
    

/***** 在以下一行填写代码 *****/
    printf("Name : %s, Age : %d\n",      (3)      ,max.age);
    

    
    return 0;
}

第3关:程序填空(3)

#include <stdio.h>
#include <string.h>
#define N 10
typedef struct ss
{
    char num[10]; 
    int s; 

} STU;

void fun( STU a[], STU *s )
{
    /********** Begin **********/
    int i;
    strcpy(s->num,a[0].num);
    s->s = a[0].s;
    for(i=0 ; i<N; i++){
        if(s->s>a[i].s){
            strcpy(s->num,a[i].num);
            s->s=a[i].s;
        }
    }  

    /********** End **********/
}

int main ( )
{
    STU a[N]={ {"A01",81},{"A02",89},{"A03",66},{"A04",87},{"A05",77},
                {"A06",90},{"A07",79},{"A08",61},{"A09",80},{"A10",71} }, m ;
    int i;
    
    printf("***** The original data *****\n");
    for ( i=0; i< N; i++ )
        printf("No = %s Mark = %d\n", a[i].num,a[i].s);

fun ( a, &m );
    
    printf ("***** THE  RESULT *****\n");
    printf ("The lowest : %s , %d\n",m.num, m.s);
    
    return 0;
}

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
结构体数组指向结构体数组是指一个结构体数组的元素是另一个结构体数组指针。这种情况通常用于需要在结构体数组中存储其他结构体数组的情况,可以实现更复杂的数据结构和数据组织方式。 下面是一个简单的示例来介绍结构体数组指向结构体数组的概念: 假设我们有两个结构体类型:Student和Class,其中Student表示学生的信息,Class表示班级的信息。 ```c typedef struct { char name[20]; int age; } Student; typedef struct { Student* students; int numStudents; } Class; ``` 在上面的示例中,Class结构体包含了一个指向Student结构体数组指针students,以及一个表示学生数量的整数numStudents。 现在我们可以创建一个Class结构体数组,并为每个班级分配一定数量的学生: ```c int main() { int numClasses = 3; int numStudentsPerClass = 5; // 创建Class结构体数组 Class classes[numClasses]; // 为每个班级分配学生数组 for (int i = 0; i < numClasses; i++) { classes[i].students = malloc(numStudentsPerClass * sizeof(Student)); classes[i].numStudents = numStudentsPerClass; } // 对每个班级的学生进行操作 for (int i = 0; i < numClasses; i++) { for (int j = 0; j < numStudentsPerClass; j++) { // 对学生进行赋值操作 strcpy(classes[i].students[j].name, "John"); classes[i].students[j].age = 18; } } // 释放内存 for (int i = 0; i < numClasses; i++) { free(classes[i].students); } return 0; } ``` 在上面的示例中,我们首先创建了一个Class结构体数组,然后为每个班级分配了一个学生数组。通过访问classes[i].students[j],我们可以对每个学生进行操作。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值