c语言 结构体 简单实例

结构体

简单例子

要求:
结构体保存学生信息操作

代码
#include <stdio.h>//定义结构体
struct student{int ID;char name[20];char sex;char birthday[8];int grade;
};int main(){int number;printf("请输入学生个数:");scanf("%d", &number);//声明结构体变量struct student stu[number];//输入数据for (int i=0; i<number; ++i){printf("请输入(每个数据用空格隔开):");scanf("%d %s %s %s %d", &stu[i].ID, &stu[i].name, &stu[i].sex, &stu[i].birthday, &stu[i].grade);}printf("--------------------------------\n");for (int i=0; i<number; ++i){printf("学号:%d\t姓名:%s\t性别:%c\t  出生日期:%s\t成绩:%d\n",stu[i].ID, stu[i].name, stu[i].sex, stu[i].birthday, stu[i].grade);}return 0;
}
运行效果

在这里插入图片描述

课堂作业

要求:
对结构体操作:输入数据,查找数据,插入数据,删除数据,合并数据比进行排列输出

代码
#include <stdio.h>
#define MAX_SIZE 100typedef struct {int data[MAX_SIZE];int length;
} SeqList;//初始化操作
void init(SeqList *list) {list->length = 0;
}//插入操作
void insert(SeqList *list, int pos, int value) {if (pos < 1 || pos > list->length + 1) {printf("插入位置错误\n");return;}if (list->length >= MAX_SIZE) {printf("顺序表已满,无法插入\n");return;}for (int i = list->length; i >= pos; i--) {list->data[i] = list->data[i - 1];}list->data[pos - 1] = value;list->length++;
}//查找操作
int find(SeqList *list, int value) {for (int i = 0; i < list->length; i++) {if (list->data[i] == value) {return i;}}return -1;
}//展示操作
void display(SeqList *list) {for (int i = 0; i < list->length; i++) {printf("%d ", list->data[i]);}printf("\n");
}//删除操作
void del(SeqList *list, int del_value){if (list->length==0){printf("线性表为空!\n");return;}int temp=0;for(int i=0; i<list->length; i++){if(list->data[i] != del_value){list->data[temp] = list->data[i];temp++;}}list->length = temp;}//合并操作,降序排列
void merge_sort(SeqList *L_A, SeqList *L_B, SeqList *L_C){int k=0;for (int i = 0; i < L_A->length; i++) {L_C->data[k] = L_A->data[i];k++;L_C->length++;}for (int j = 0; j < L_B->length; j++) {L_C->data[k] = L_B->data[j];k++;L_C->length++;}//冒泡排序for(int x=0; x <= L_C->length -1; x++){for(int y=0; y <= L_C->length-x; y++){if(L_C->data[y] < L_C->data[y+1]){int temp = L_C->data[y];L_C->data[y] = L_C->data[y+1];L_C->data[y+1] = temp;}}}
}//升序排列
void merge_ascending(SeqList *L_C, SeqList *L_D){int i=0;for(int k=L_C->length-1; k>=0; k--){L_D->data[k] = L_C->data[i];L_D->length++;i++;}
}int main() {//声明结构体变量SeqList L_A;SeqList L_B;SeqList L_C;SeqList L_D;//初始化init(&L_A);init(&L_B);init(&L_C);init(&L_D);// 用户输入数据printf("请输入数据(每输入一个数据后回车,输入777可结束):\n");for (int i = 0; i < MAX_SIZE; i++) {int data_value;scanf("%d", &data_value);if(data_value == 777){break;}L_A.data[i] = data_value;L_A.length++;}// 默认查找数据 4,并输出数据4的位置int index = find(&L_A, 4);if (index != -1) {printf("找到数据 4,位置为:%d\n", index + 1);} else {printf("未找到数据 4\n");}// 在第四个位置上插入数据 100int in_value;printf("请输入要插入的数字:\n");scanf("%d", &in_value);insert(&L_A, index+1, in_value);// 展示数据表结果display(&L_A);// 删除操作printf("请输入删除的数字:\n");int del_value;scanf("%d",&del_value);del(&L_A, del_value);// 展示数据表结果display(&L_A);// 输入第二个数据表并进行合并操作printf("请输入第二个数据表的数据,(每输入一个数据后回车,输入777可结束)\n");for (int i = 0; i < MAX_SIZE; i++) {int data_value;scanf("%d", &data_value);if(data_value == 777){break;}L_B.data[i] = data_value;L_B.length++;}printf("第二个数据表的数据为:\n");display(&L_B);printf("\n");//降序排列printf("降序排列为:\n");merge_sort(&L_A, &L_B, &L_C);//展示数据表结果display(&L_C);printf("\n");//升序排列printf("升序排列为:\n");merge_ascending(&L_C, &L_D);// 展示数据表结果display(&L_D);return 0;
}
运行效果

在这里插入图片描述

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

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

相关文章

lua中的循环 while、for、repeat until三种循环方式、pairs和ipairs区别

lua中的循环 while、for、repeat until三种循环方式、pairs和ipairs区别 介绍for循环参数ipairs和pairs whilerepeat until总结 介绍 这里我用while、for、repeat until分别输出1-20之间的奇数 &#xff0c;具体的语法可以看下面的代码 for循环 参数 定义一个初始值为start…

ARM64 linux并发与同步之原子操作

卷2&#xff1a;调试与案例分析 第一章 并发与同步 画了两张简图&#xff0c;方便理解&#xff0c;如下&#xff1a; 针对并发源的问题&#xff0c;我接触的项目中都是SMP系统&#xff0c;目前大部分也都是SMP系统&#xff1b; 对于SMP系统&#xff0c;情况会更复杂。 □ 同…

Servlet详解

一.Servlet生命周期 初始化提供服务销毁 1.测试生命周期 package com.demo.servlet;import javax.servlet.*; import java.io.IOException;public class LifeServlet implements Servlet {Overridepublic void init(ServletConfig servletConfig) throws ServletException {…

ros的安装和rosdep的初始化操作

ros的安装 安装ROS完整桌面版安装&#xff08;Desktop-Full&#xff09;环境配置rosdep初始化 安装ROS完整桌面版安装&#xff08;Desktop-Full&#xff09; 官网 选择思想者乌龟 选择ubuntu平台 操作 开始安装ROS 完整桌面版安装&#xff08;Desktop-Full&#xff0c;推荐…

小白学爬虫:手机app分享商品短连接获取淘宝商品链接接口|淘宝淘口令接口|淘宝真实商品链接接口|淘宝商品详情接口

通过手机APP分享的商品短链接&#xff0c;我们可以调用相应的接口来获取淘口令真实URL&#xff0c;进而获取到PC端的商品链接及商品ID。具体步骤如下&#xff1a; 1、通过手机APP分享至PC端的短链接&#xff0c;调用“item_password”接口。 2、该接口将返回淘口令真实URL。 3…

如何规划并新建大数据平台的独立生产域?5步走

一般来说&#xff0c;大数据平台包括以下4类数据生产域——生产生态环境&#xff08;正式生产环境&#xff09;、开发和测试环境、培训和演示环境、灾备环境。各生产域在由平台提供资源、安全、监控、故障恢复等保障的同时&#xff0c;不同的生产域之间还需要严格隔离&#xff…

基于生成对抗网络的照片上色动态算法设计与实现 - 深度学习 opencv python 计算机竞赛

文章目录 1 前言1 课题背景2 GAN(生成对抗网络)2.1 简介2.2 基本原理 3 DeOldify 框架4 First Order Motion Model5 最后 1 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 &#x1f6a9; 基于生成对抗网络的照片上色动态算法设计与实现 该项目较为新颖&am…

Qt OpenMP使用

1、概念 OpenMP是一种用于共享内存并行系统的多线程程序设计方案&#xff0c;支持的编程语言包括C、C和Fortran。OpenMP提供了对并行算法的高层抽象描述&#xff0c;特别适合在多核CPU机器上的并行程序设计。编译器根据程序中添加的pragma指令&#xff0c;自动将程序并行处理&…

Android transform旋转rotate圆角矩形图roundedCorners,Kotlin

Android transform旋转rotate圆角矩形图roundedCorners&#xff0c;Kotlin import android.graphics.Bitmap import android.os.Bundle import android.util.Log import android.widget.ImageView import androidx.appcompat.app.AppCompatActivity import com.bumptech.glide.…

Antd Procomponent 之 proForm - 高级表单

本文作者系360奇舞团前端开发工程师 ProForm 在原来的 Form 基础上增加一些语法糖和更多的布局设置&#xff0c;帮助我们快速的开发一个表单。同时添加一些默认行为&#xff0c;让我们的表单默认好用。分步表单&#xff0c;Modal 表单&#xff0c;Drawer 表单&#xff0c;查询表…

Leetcode 第 369 场周赛题解

Leetcode 第 369 场周赛题解 Leetcode 第 369 场周赛题解题目1&#xff1a;2917. 找出数组中的 K-or 值思路代码复杂度分析 题目2&#xff1a;2918. 数组的最小相等和思路代码复杂度分析 题目3&#xff1a;2919. 使数组变美的最小增量运算数思路代码复杂度分析 题目4&#xff1…

腾讯、巨量等头部营销平台方法论

媒体、营销与市场生态正处于新一轮变革期&#xff0c;尤其是进入移动互联网时代后&#xff0c;行业话语权由创意人转向互联网人&#xff0c;营销的风向与规则&#xff0c;也越来越由掌握流量与资源的头部平台引领。 巨变之下&#xff0c;企业只有从本质层面&#xff0c;认清变…