数据结构作业day2

作业一:结构体数组存储学生信息(姓名,年龄,分数),完成输入学生信息,输出学生信息,求学生成绩之和,求最低学生成绩。

main.c

cpp 复制代码
#include "test.h"

int main(int argc, const char *argv[])
{
	Pstu p = malloc(sizeof(stu)*5);
	input(p,5);
	output(p,5);

	qiuhe(p,5);
	find(p,5);
	return 0;
}

hanshu.c

cpp 复制代码
#include"test.h"

void input(Pstu p,int n)
{
	int i;
	printf("请输入学生信息:\n");
	for(i=0;i<n;i++)
	{
		scanf("%s%d%d",p[i].name,&p[i].age,&p[i].score);
	}
}

void output(Pstu p,int n)
{
	int i;
	for(i=0;i<n;i++)
	{
		printf("姓名:%s\t年龄:%d\t分数:%d\n",p[i].name,p[i].age,p[i].score);
	}
}

void qiuhe(Pstu p,int n)
{
	int i,sum=0;
	for(i=0;i<n;i++)
	{
		sum = sum + p[i].score;
	}
	printf("所有学生的成绩总和为:%d\n",sum);
}

void find(Pstu p,int n)
{
	int i,min=0,sub=-1;
	for(i=0;i<n;i++)
	{
		if(p[i].score<p[min].score)
		{
			min = i;
			sub++;
		}
	}
	if(sub != -1)
	{
		printf("最低学生成绩的分数:%d\n",p[min].score);
	}
	else
	{
		printf("最低学生成绩的分数:%d\n",p[min].score);
	}
}

test.h

cpp 复制代码
#ifndef _TEST_H_
#define _TEST_H_
#include <myhead.h>

typedef struct
{
	char name[20];
	int age;
	int score;
}stu,*Pstu;

void input(Pstu,int n);
void output(Pstu,int n);
void qiuhe(Pstu,int n);
void find(Pstu,int n);
#endif

作业二:在堆区,申请5个结构体空间,存储学生信息(姓名,分数)

循环输入学生信息,按照输入姓名查找某个学生,修改其成绩为100分。

main.c

cpp 复制代码
#include "test.h"
int main(int argc, const char *argv[])
{
	Pstu p = apply(5);
	input(p,5);
	output(p,5);

	printf("请输入要查找的姓名:");
	
	char key[20];
	scanf("%s",key);
	find(p,key,5);
	output(p,5);

	return 0;
}

hanshu.c

cpp 复制代码
#include "test.h"
Pstu apply(int n)
{
	Pstu p = malloc(sizeof(stu)*n);
	if(p==NULL)
	{
		printf("申请空间失败\n");
		return NULL;
	}
	else
	{
		printf("申请成功!\n");
		return p;
	}
}


void input(Pstu p,int n)
{
	int i;
	for(i=0;i<n;i++)
	{
		printf("请输入第%d个学生信息:",i+1);
		scanf("%s%d",p[i].name,&p[i].score);
	}
}

void output(Pstu p,int n)
{
	int i;
	for(i=0;i<n;i++)
	{
		printf("姓名:%s,成绩:%d\n",p[i].name,p[i].score);
	}

}

void find(Pstu p,char key[],int n)
{
	int i,sub=-1;
	for(i=0;i<n;i++)
	{
		if(strcmp(p[i].name,key)==0)
		{
			sub = i;
		}
	}
	if(sub!=-1)
	{
		printf("查找成功,该学生分数为:%d\n",p[sub].score);
		p[sub].score = 100;
	}
	else
	{
		printf("查找失败!");
	}

}

test.h

cpp 复制代码
#ifndef _TEST_H_
#define _TEST_H_
#include <myhead.h>

typedef struct
{
	char name[20];
	int score;
}stu,*Pstu;

Pstu apply(int);
void input(Pstu,int);
void output(Pstu,int);
void find(Pstu,char key[],int);
#endif

xmind

相关推荐
纪元A梦1 小时前
贪心算法应用:化工反应器调度问题详解
算法·贪心算法
阿让啊2 小时前
C语言strtol 函数使用方法
c语言·数据结构·c++·单片机·嵌入式硬件
深圳市快瞳科技有限公司2 小时前
小场景大市场:猫狗识别算法在宠物智能设备中的应用
算法·计算机视觉·宠物
liulilittle2 小时前
OPENPPP2 —— IP标准校验和算法深度剖析:从原理到SSE2优化实现
网络·c++·网络协议·tcp/ip·算法·ip·通信
superlls5 小时前
(算法 哈希表)【LeetCode 349】两个数组的交集 思路笔记自留
java·数据结构·算法
田里的水稻5 小时前
C++_队列编码实例,从末端添加对象,同时把头部的对象剔除掉,中的队列长度为设置长度NUM_OBJ
java·c++·算法
纪元A梦5 小时前
贪心算法应用:保险理赔调度问题详解
算法·贪心算法
Ripple123126 小时前
数据结构:顺序表与链表
数据结构·链表
Jayden_Ruan6 小时前
C++逆向输出一个字符串(三)
开发语言·c++·算法
一个响当当的名号7 小时前
B树,B+树,B*树(无代码)
数据结构·b树