首页 > 其他分享 >20240323, 结构STRUCT,

20240323, 结构STRUCT,

时间:2024-03-23 23:32:56浏览次数:28  
标签:struct int mouth 20240323 year 结构 day today STRUCT

二,结构

2.1 结构类型

2.1.1 声明结构类型:

函数内声明只能函数内使用,通常声明在函数外部,可以多个函数一起使用

#include<stdio.h>
int main() {
	struct data {
		int mouth;
		int day;
		int year;
	};
	//不要忘记分号
	struct data today;
	today.mouth = 07;
	today.day = 31;
	today.year = 2014;
	printf("Todday's date is %i-%i-%i.\n",
		today.day, today.mouth, today.year);

	return 0;
}
#include<stdio.h>
struct data {
	int mouth;
	int day;
	int year;
};
int main() {
	struct data today;
	today.mouth = 07;
	today.day = 31;
	today.year = 2014;
	printf("Todday's date is %i-%i-%i.\n",
		today.day, today.mouth, today.year);
	return 0;
}
2.1.2 声明的形式

三种,结构类型,结构变量

struct data {
	int mouth;
	int day;
	int year;
};
struct data today;
struct data jintian;
//有结构类型名字,有变量
	struct {
		int mouth;
		int day;
		int year;
	}today,jintian;
//无名结构
	struct data {
		int mouth;
		int day;
		int year;
	}today,jintian;
//声明结构,定义两个变量
2.1.3  结构初始化
#include<stdio.h>//结构初始化--近数组
struct data {
	int mouth;
	int day;
	int year;
}today, jintian;

int main() {
	//结构变量的使用一定要带上 STRUCT 结构名称 变量名
	struct data today = { 07,31,2014 };
	struct data jintian = { .mouth = 7,.year = 2014 };
	printf("Todday's date is %i-%i-%i.\n",
		today.day, today.mouth, today.year);
	printf("Todday's date is %i-%i-%i.\n",
	jintian.day, jintian.mouth, jintian.year);
	return 0;
}

结构成员,数组用[ ]访问数组成员,结构用 . 运算符访问结构成员【访问单个成员】
要访问整个结构,直接用结构变量的名字
对于整个结构,可以赋值,取地址,也可以传递给函数参数

2.1.4 结构运算
#include<stdio.h>
struct data {
	int mouth;
	int day;
	int year;
}today, jintian;

int main() {

	struct data today = { 07,31,2014 };
	struct data jintian = { .mouth = 3,.year = 2024 };
	printf("Todday's date is %i-%i-%i.\n",
		today.day, today.mouth, today.year);
	printf("Todday's date is %i-%i-%i.\n",
	jintian.day, jintian.mouth, jintian.year);

	//赋值
	today = jintian;
	printf("Todday's date is %i-%i-%i.\n",
		today.day, today.mouth, today.year);

	struct data i;//INT I不行
	i = (struct data){ 9,24,2024 };
	//强制类型转换,但是I不可以INT 不懂
	printf("Todday's date is %i-%i-%i.\n",
		i.day, i.mouth, i.year);

	i.year = 2014;
	printf("Todday's date is %i-%i-%i.\n",
		i.day, i.mouth, i.year);
	return 0;
}

2.1.5 结构指针

结构变量的名字不是结构变量的地址,需要使用&运算符

#include<stdio.h>
struct data {
	int mouth;
	int day;
	int year;
}today, jintian;
int main() {
	struct data today = { 3,23,2024 };
	struct  data* pData = &today;
	scanf_s("%d", pData);
	printf("%i-%i-%i\n", today.mouth, today.day, today.year);
	//只能输入MOUTH
	return 0;
}

没有直接的办法可以一次 scanf 一个结构 

2.2 结构与函数

2.2.1 结构作为函数参数

整个结构可以作为  参数的值  传入函数,可以在函数内新建一个结构变量,并复制调用者的结构的值,也可以返回一个结构

#include<stdio.h>//明天-日历
#include<stdbool.h>

struct date {
	int mouth;
	int day;
	int year;
};

bool isLeap(struct date d);
//逻辑类型,TRUE=1,FAULTH=0
//判断闰年
int numofdays(struct date d);
//判断月份--天数

int main(int argc,char const* argv[]) {
	struct date today, tom;
	printf("Enter today's date (mm dd yyyy):");
	scanf_s("%i %i %i", &today.mouth, &today.day, &today.year);
	if (today.day != numofdays(today)) {
		tom.day = today.day + 1;
		tom.mouth = today.mouth;
		tom.year = today.year;
	}//不是当月最后一天
	else if (today.mouth == 12) {
		tom.day = 1;
		tom.mouth = 1;
		tom.year = today.year + 1;
	}//是当月最后一天且是一年最后一天
	else {
		tom.day = 1;
		tom.mouth = today.mouth + 1;
		tom.year = today.year;
	}
	printf("TOMORROW'S DATE IS %i-%i-%i.\n",
		tom.mouth, tom.day, tom.year);
	return 0;
}

bool isLeap(struct date d) {
	bool leap = false;
	if ((d.year % 4 == 0 && d.year % 100 != 0) || d.year % 400 == 0) {
		leap = true;
	}//非整百年份除4整除,整百除400,1900不是闰年
	return leap;
}

int numofdays(struct date d) {
	int days;
	const int daysofmouth[12] = { 31,28,31,30,31,30,31,31,30,31,30,31 };
	if (d.mouth == 2 && isLeap(d)) {
		days = 29;
	}
	else {
		days = daysofmouth[d.mouth - 1];
	}
	return days;
}
2.2.2 输入结构

没有直接的办法可以一次 scanf 一个结构 

#include<stdio.h>
#include<stdbool.h>

struct point {
	int x;
	int y;//多打了一个分号直接去世
};

void get(struct point p) {
	scanf_s("%d", &p.x);
	scanf_s("%d", &p.y);
	printf("%d,%d\n", p.x, p.y);
}
void put(struct point p) {
	printf("%d,%d\n", p.x, p.y);
}
void main() {
	struct point pp = { 0,0 };
	get(pp);
	put(pp);
	return 0;
}

函数都是传值的,上面的函数操作的时候是设置了一个结构变量,复制了传进去的结构变量,但是没有改动他,出了函数,函数内的结构变量不起作用了
改动 1.0——返回结构变量 

#include<stdio.h>
#include<stdbool.h>
struct point {
	int x;
	int y;
};

struct point get(void) {
	struct point p;//不能忘记
	scanf_s("%d", &p.x);
	scanf_s("%d", &p.y);
	printf("%d,%d\n", p.x, p.y);
	return p;//不能忘记
}
void put(struct point p) {
	printf("%d,%d\n", p.x, p.y);
}
int main() {
	struct point pp = { 0,0 };
	pp = get();
	put(pp);
	return 0;
}
2.2.3 指向结构的指针
struct  data* pData = &today;
(*pData).mouth = 12;
p->mouth = 12;

改进 2.0 ,妈的嘎嘎出不来,烦,

#include<stdio.h>
struct cc{
	int x;
	int y;
};
struct cc* get(struct cc *p);

int main(int argc, const int* argv[]) {
//错误1111111啊啊啊啊啊啊
	struct cc ddd = { 0,0 };
	get(&ddd);
}
struct cc* get(struct cc* p) {
	scanf_s("%d", p>x);
//错误2啊啊啊啊啊啊啊啊啊啊啊
	scanf_s("%d", p>y);
	printf("%d,%d\n", p->x, p->y);
}

所以是-》符号的问题吗?这玩意怎么一键打出来????啊
狗东西!!!int argc, char const* argv[ ]     heheh 
这个狗地方再错是小狗!!是!小!狗!、

CHAR CONST *ARGV[ ]是字符串数组,数组带入函数需要另一个整数告诉函数数组有多大,INT ARGC就是那个整数,两个变量,整数,字符串数组

#include<stdio.h>
struct cc{
	int x;
	int y;
};
struct cc* get(struct cc *p);

int main() {
	struct cc ddd = { 0,0 };
	get(&ddd);
	return 0;
}
struct cc* get(struct cc* p) {
	scanf_s("%d", &p->x);
	scanf_s("%d", &p->y);
	printf("%d,%d\n", &p->x,&p->y);
	printf("%d,%d\n", p->x, p->y);
	//妈的,妈的,妈的//是&p->x
	return p;
}

我真的,睁大我的狗眼看清楚啊啊啊啊,P->X是一个变量,SCANF是对地址操作,所以还要取一次地址,啊啊啊啊啊我的脑子!!!谁吃了我的脑子!!! 
啊啊啊啊啊啊啊啊啊啊啊啊!!!多~么~痛~的~零~五~~~

#include<stdio.h>
struct cc{
	int x;
	int y;
};
struct cc* get(struct cc *p);
void put(struct cc);
void put2(struct cc* p);
int main() {
	struct cc ddd = { 0,0 };
	get(&ddd);
	put(ddd);
	put(*get(&ddd));
	put2(&ddd);
	put2(get(&ddd));
	*get(&ddd) = (struct cc){ 1,2 };//稍微有点不懂,为什么要强制类型转换
	printf("%d %d", ddd.x, ddd.y);
	//GET函数包括输入,所以,MAIN里面要输入4次
	return 0;
}
struct cc* get(struct cc* p) {
	scanf_s("%d", &p->x);
	scanf_s("%d", &p->y);
	printf("%d,%d\n", &p->x,&p->y);
	printf("%d,%d\n", p->x, p->y);
	//妈的,妈的,妈的//是&p->x
	//传进来是指针P还是&ddd都一样啊啊啊啊
	return p;
}
void put(struct cc p) {
	printf("%d %d\n", p.x, p.y);
}
void put2(struct cc *p) {
	printf("%d %d\n", p->x, p->y);
}

2.3 结构中的结构

三,联合

3.1 类型定义

3.2 联合

标签:struct,int,mouth,20240323,year,结构,day,today,STRUCT
From: https://blog.csdn.net/qq_51583806/article/details/136966675

相关文章

  • Python 潮流周刊第 43 期(摘要),赠书 5 本《Python数据结构与算法分析(第3版)》
    本周刊由Python猫出品,精心筛选国内外的250+信息源,为你挑选最值得分享的文章、教程、开源项目、软件工具、播客和视频、热门话题等内容。愿景:帮助所有读者精进Python技术,并增长职业和副业的收入。周刊全文:https://pythoncat.top/posts/2024-03-23-weekly特别提醒:本期赠书5......
  • 数据结构(五)——二叉树的遍历和线索二叉树
    5.3.二叉树的遍历和线索二叉树5.3.1_1二叉树的先中后序遍历遍历:按照某种次序把所有结点都访问一遍二叉树的递归特性:        ①要么是个空二叉树        ②要么就是由“根节点+左子树+右子树”组成的二叉树先序遍历:根左右(NLR)中序遍历:左根右(LNR)后序遍......
  • 算法模板 v1.10.3.20240323
    算法模板v1.1.1.20240115:之前历史版本已不可寻,创建第一份算法模板。v1.2.1.20240116:删除“编译”-“手动开栈”;删除“编译”-“手动开O优化”;修改“编译”-“CF模板”;删除“读写”;删除“图论”-“欧拉图”-“混合图”;删除“图论”-“可达性统计”;删除“数据类型”-“高精类”。......
  • 政安晨:【深度学习实践】【使用 TensorFlow 和 Keras 为结构化数据构建和训练神经网络
    政安晨的个人主页:政安晨欢迎 ......
  • SAR图像辐射分辨率和等效视数(CSDN_20240323)
            辐射分辨率和等效视数,是基于面目标评价SAR图像质量的两项重要指标。在介绍辐射分辨率和等效视数之前,首先介绍SAR图像的均值和方差。均值图像均值指的是SAR幅度图的统计平均,该指标反映了地物目标的平均后向散射系数,具体定义如下:其中,M和N分别表示SAR图像的......
  • 《数据结构与算法分析》作业一(详解版)
    1.什么是数据结构?有关数据结构的讨论涉及哪三个方面?答:(1)数据结构是指相互之间存在着一种或多种关系的数据元素的集合和该集合中数据元素之间的关系组成.(2)逻辑结构、存储结构以及运算结构。2.什么是算法?算法的特性有哪些?根据这些特性,解释算法与程序的区别?答:(1)算法是一组明......
  • 结构体和联合体的存储
    今天我们来看看结构体和联合体的存储,新的一天,卯足精神,冲冲冲!!!目录结构体的存储偏移量,对齐数,默认对齐数方法一:将相同类型的成员都放在一起方法二:使用位段位段的跨平台问题位段使用的注意事项联合体的存储总结结构体的存储我们已经了解了整型类型,浮点数,字符数的存......
  • 自定义类型结构体♪♪♪
    目录结构体结构体的声明结构体的变量的定义结构体的变量的初始化结构成员访问操作符结构体的特殊声明(匿名结构体)结构体重命名结构体内存对齐对齐规则:为什们要存在内存对齐?怎样设计结构体使其占用内存空间大小尽量小一点?修改默认对齐数结构体传参结构体实现位段......
  • python 内置数据结构-数值型
    内置数值型数据结构int整数(int):在Python中,整数是没有小数部分的数字。整数可以是正数、负数或零。Python中的整数没有大小限制,取决于内存区域的大小,可以表示任意大小的整数。x=10y=-5z=0print(x,y,z)#输出:10-50float浮点数(float):浮点数是带有小数......
  • 可持久化数据结构
    前言可持久化数据结构是一些很厉害的东西,大家可以去看lxl的课件和她在WC2024上的讲课,由于能力限制,这个博客会讲得比较基础。这里应该有个题单。根据lxl的课件,我们可以把其分为几类:部分可持久化:允许访问历史版本,不能修改历史版本完全可持久化:允许把目前版本替换为历史......