数据结构 / day02作业

1.

有若干个学校人员的信息,包括学生和教师。 其中学生的数据包括:姓名、性别、职业s/S、分数。 教师的数据包括:姓名、性别、职业t/T、职务。 1,定义指针指向堆区内存 2.循环输入 3.计算老师的个数 4.计算学生的平均值 5.循环输出 6·释放堆区空间

#include <string.h>
#include <stdlib.h>
#include <stdio.h>typedef union diff
{int score;char pos[20];}diff_t;typedef struct person
{char name[20];char gender;char job;diff_t score_or_pos;} person_t;                                                                                   person_t *req_mem(int n);
void input(int n, person_t *parr);
int count(char job, int n, person_t *parr);
void output(int n, person_t *parr);
person_t *free_mem(person_t *parr);
float avg(int n, person_t *parr);int main(int argc, const char *argv[])
{int n=3;//定义指针向堆区的内存person_t *parr=req_mem(n);/*//testperson_t arr_p[]={"zhang", 'f', 's', 98,"li", 'f', 't', "class teacher","wang", 'm', 't', "schoolmaster","zhao", 'f', 's', 97}*///输入input(n, parr);//计算老师个数int teachers = count('t', n, parr);putchar(10);printf("teacher count=%d\n", teachers);int students = count('s', n, parr);putchar(10);printf("students count=%d\n", students);//计算学生的平均值putchar(10);float  av=avg(n, parr);printf("students avg score=%.2lf\n", av);//输出putchar(10);output(n, parr);//释放堆区空间parr=free_mem(parr);return 0;
}person_t *req_mem(int n)
{person_t *p=(person_t*)malloc(sizeof(person_t)*n);if(NULL==p){printf("error");return NULL;}return p;}void input(int n, person_t *parr)                                                                                        
{for(int i=0; i<n; i++){printf("please input %d name:", i+1);scanf("%s", (parr+i)->name);printf("please input  %d gender:", i+1);scanf(" %c", &(parr+i)->gender);printf("please input %d job:", i+1);scanf(" %c", &(parr+i)->job);if('s'==((parr+i)->job) || 'S'==(parr+i)->job){printf("please input %d score:", i+1);scanf("%d", &(parr+i)->score_or_pos.score);}else if('t'==((parr+i)->job) || 'T'==(parr+i)->job){printf("please input %d position:", i+1);scanf("%s", (parr+i)->score_or_pos.pos);}}}int count(char job, int n, person_t *parr)
{int count_s=0;int count_t=0;for(int i=0; i<n; i++){char cj=(parr+i)->job;if(cj=='t'||cj=='T'){count_t++;}else if(cj=='s'||cj=='S'){count_s++;}}if (job=='t'||job=='T'){return count_t;}else if('s'==job||'T'==job){return count_s;}return -1;}      float avg(int n, person_t *parr)
{int sum=0;int count=0;for(int i=0; i<n; i++)                                                                                           {char cj = (parr+i)->job;if('s'==cj||'S'==cj){sum+=(parr+i)->score_or_pos.score;count++;}}if(count>0){return (float)sum*1.0/count;}else{return 0;}}void output(int n, person_t *parr)
{for(int i=0; i<n; i++){printf("No. %d person info:\n", i+1);printf("name=%s, gender=%c, job=%c, ", (parr+i)->name, (parr+i)->gender, (parr+i)->job );char cj=(parr+i)->job;if('s'==cj||'S'==cj){printf("score=%d\n", (parr+i)->score_or_pos.score);}else if('t'==cj||'T'==cj){printf("position=%s\n", (parr+i)->score_or_pos.pos);}putchar(10);}putchar(10);
}person_t *free_mem(person_t *parr)
{if(NULL==parr){return NULL;}free(parr);parr=NULL;return parr;}     
please input 1 name:w
please input  1 gender:f
please input 1 job:s
please input 1 score:90
please input 2 name:a
please input  2 gender:f
please input 2 job:s
please input 2 score:92
please input 3 name:n
please input  3 gender:f
please input 3 job:t
please input 3 position:class teacherteacher count=1students count=2students avg score=91.00No. 1 person info:
name=w, gender=f, job=s, score=90No. 2 person info:
name=a, gender=f, job=s, score=92No. 3 person info:
name=n, gender=f, job=t, position=class

2.

以下结构体使用sizeof 计算大小的结果(默认4字节对齐)

struct s1
{char ch;int a;double b;char c1;};

 

s1-->20
0x00ch
0x01 
0x02 
0x03 
0x04a
0x05 
0x06 
0x07 
0x08b
0x09 
0x0A 
0x0B 
0x0C 
0x0D 
0x0E 
0x0F 
0x20c1
0x21 
0x22 
0x23 

 写一个简单的宏, 交换A, B两数的值(假设两个变量都是char 或int类型)

struct s2
{char ch;int a;double b;};

s2-->16
0x00ch
0x01 
0x02 
0x03 
0x04a
0x05 
0x06 
0x07 
0x08b
0x09 
0x0A 
0x0B 
0x0C 
0x0D 
0x0E 
0x0F 

struct s3
{char i;struct{char c;};char a;char b;char d;char e;char f;};

s3->12
0x00i
0x01 
0x02 
0x03 
0x04c
0x05a
0x06b
0x07d
0x08e
0x09f
0x0A 
0x0B 

3.

写一个简单的宏,交换两数的值(假设两个变量都是char或int类型)

#include <string.h>
#include <stdlib.h>
#include <stdio.h>#define EXCHANGE a=a+b; b=a-b; a=a-b;                                 int main(int argc, const char *argv[])
{int a=2;int b=3;printf("before exchange: a=%d, b=%d\n", a, b );EXCHANGE;printf("afterbefore exchange: a=%d, b=%d\n", a, b );return 0;
}

4.

关键字static有什么含义

1.static修饰全局变量未初始化,默认结果为0

2.static修饰的局部,延长生命周期至本文件有效,但不是作用域

3.static修饰函数, 不可以跨文件调用,static修饰的函数生命周期在本文件有效

4.static修饰指针, static修饰的指针不要指向auto类型的变量地址

5.

思维导图

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/182841.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Jquery中的bind(),live(),delegate(),on()绑定事件方式

bind() 简要描述 bind()向匹配元素添加一个或多个事件处理器。 使用方式 $(selector).bind(event,data,function) event&#xff1a;必需项&#xff1b;添加到元素的一个或多个事件&#xff0c;例如 click,dblclick等&#xff1b; 单事件处理&#xff1a;例如 $(selector).bi…

不同类型的开源许可证

不同类型的开源许可证 什么是开源许可证 最简单的解释是&#xff0c;开源许可证是计算机软件和其他产品的许可证&#xff0c;允许在定义的条款和条件下使用、修改或共享源代码、蓝图或设计。开源并不意味着该软件可以根据需要使用、复制、修改和分发。根据开源许可证的类型&a…

gcp, loki, honeybadger 查看日志 语句

gcp, loki, honeybadger 查看日志 语句 GCP resource.type“cloudsql_database” AND logName:“projects/ebay-mag/logs/cloudsql.googleapis.com%2Fpostgres.log” AND ( textPayload:“[2823409]”) log_name“projects/ebay-mag/logs/cloudsql.googleapis.com%2Fpostgres…

代码随想录算法训练营第四十九天 | 121. 买卖股票的最佳时机,122.买卖股票的最佳时机II

目录 121. 买卖股票的最佳时机 122.买卖股票的最佳时机II 121. 买卖股票的最佳时机 题目链接&#xff1a;121. 买卖股票的最佳时机 比较好想到的是贪心算法&#xff0c;贪心选择价格更低的日子买入&#xff0c;价格更高的日子卖出。 class Solution { public:int maxProfit(vec…

ROS命令行工具

1、roscore 在使用ROS之前&#xff0c;首先要启动roscore进程。当我们在终端中运行这个命令时&#xff0c;系统就会启动ROS Master、参数服务器和日志节点。在这之后&#xff0c;就可以运行任何其他的ROS程序&#xff0f;节点了。所以可以在一个终端窗口运行roscore指令&#…

【unity实战】基于权重的随机事件(附项目源码)

文章目录 前言开始一、简单的使用二、完善各种事件1. 完善生成金币事件2. 完善生成敌人事件敌人3. 完善生成药水事件 最终效果参考源码完结 前言 随机功能和UnityEvent前面其实我们都已经做过了&#xff0c;但是随机UnityEvent事件要怎么使用呢&#xff1f;这里就来举一个例子…

【Linux驱动开发】编译Android12源码+

编译Android12源码 1. 简单描述2. 准备资料3. 编译Android12 1. 简单描述 基于讯为电子rk3568教程 2. 准备资料 rk_android12.0_sdk_20220720.tar.gz 3. 编译Android12 解压 tar -vxf rk_android12.0_sdk_20220720.tar.gz设置屏幕配置 rk_android12.0_sdk/kernel-4.19/ar…

关于src别名的配置之tsconfig.json配置

tsconfig.json {"compilerOptions": {"baseUrl": "./", // 解析非相对模块的基地址&#xff0c;默认是当前目录"paths": { //路径映射&#xff0c;相对于baseUrl"/*": ["src/*"] }} } ① "baseUrl": &…

力扣 226.反转二叉树

目录 1.解题思路2.代码实现 1.解题思路 该题思路很简单&#xff0c;就是利用递归&#xff0c;将每次的root结点的左右树相互交换即可&#xff0c;最后再返回root结点. 2.代码实现 struct TreeNode* invertTree(struct TreeNode* root) { if(rootNULL)return NULL;struct Tree…

由于找不到steam_api64.dll如何修复?steam_api64.dll丢失多种解决方法

steam_api64.dll文件介绍 steam_api64.dll是Steam平台的一个关键组件&#xff0c;主要用于支持Steam客户端和相关游戏的应用程序。这个文件缺失或损坏会导致Steam及相关游戏无法正常运行。它位于Steam安装目录的bin子文件夹中。 steam_api64.dll丢失的原因 系统误删&#xf…

专攻C++真题合集(1)

C语言作为一门广泛使用的编程语言&#xff0c;已经成为了许多IT领域从业者的必备技能之一。为了帮助大家更好地掌握C语言&#xff0c;本文将为大家提供一些专门的C真题。 1. 指针 题目一&#xff1a;请编写一个函数&#xff0c;函数名为swap&#xff0c;交换两个整数型变量的…

爬虫代理技术与构建本地代理池的实践

爬虫中代理的使用&#xff1a; 什么是代理 代理服务器 代理服务器的作用 就是用来转发请求和响应 在爬虫中为何需要使用代理&#xff1f; 隐藏真实IP地址&#xff1a;当进行爬取时&#xff0c;爬虫程序会发送大量的请求到目标网站。如果每个请求都使用相同的IP地址&#xff…

【C++】POCO学习总结(七):进程、管道、进程间同步、共享内存

【C】郭老二博文之&#xff1a;C目录 1、Poco::Process 进程 1.1 说明 Poco::Process的功能&#xff1a; 获取有关当前进程的一些信息开始一个新的进程终止另一个进程 1.2 用法 头文件&#xff1a;#include “Poco/Process.h” Poco::Process中的所有方法都是静态的。 常…

修复 MyBatis 中空值引起的 SQL 语法错误

修复 MyBatis 中空值引起的 SQL 语法错误 背景 最近在查看别人的项目代码时&#xff0c;遇到了一个问题&#xff1a;数据库中的数据为空。在调试过程中&#xff0c;发现问题出现在调用 MyBatis 中的方法&#xff1a;listByIds(Collection<? extends Serializable> idL…

[cmake] --- find_package

1 find_package的作用 find_package是CMake中用于查找并加载外部库的指令。它可以根据指定的参数在系统或用户指定的路径中查找库文件&#xff0c;并生成相应的变量供后续使用。 2 find_package基本语法 find_package(<PackageName> [version] [EXACT] [QUIET] [MODUL…

医学机器学习数据集介绍与使用 ABIDE Autism Brain Imaging Data Exchange I

ABIDE I 简介 自闭症脑成像数据交换I&#xff08;ABIDE I&#xff09;代表了第一个ABIDE倡议。作为基层工作&#xff0c;ABIDE I涉及17个国际站点&#xff0c;共享以前收集的静息态功能磁共振成像&#xff08;R-fMRI&#xff09;、解剖和表型数据集&#xff0c;这些数据集可供…

.net core 封装一个统一的返回结果

public class ApiResponse<T> { public bool Success { get; set; } public T? Data { get; set; } public string? Message { get; set; } public ApiResponse(bool success, T? data, string errorMessage "") { …

矩阵快速幂及应用实战[C/C++]

矩阵快速幂 矩阵快速幂可以用来优化递推问题&#xff0c;如状态机DP&#xff0c;需要一丢丢线性代数里面矩阵的概念&#xff0c;只需要知道简单的矩阵乘法&#xff0c;结合我们普通的二分快速幂就能很快的掌握矩阵快速幂。 问题引入 三步问题。有个小孩正在上楼梯&#xff0c;楼…

选择三个机器学习算法,代码实现 ,并选择一个数据集进行性能分析

1. 线性回归算法 线性回归是一种用于预测连续数值的监督学习算法。以下是使用Python和scikit-learn库实现线性回归的示例代码&#xff1a; import numpy as np from sklearn.linear_model import LinearRegression from sklearn.model_selection import train_test_split from…

Linux(openssl):X509_verify通过ca证书的public key验证证书的签名

/docs/man3.0/man3/X509_verify.html (openssl.org) 提供了方法用于通过ca证书的public key验证证书的签名 //verify_cert.hpp #include <string> #include <memory> #include <filesystem> #include <openssl/pem.h>using namespace std; namespace …