栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

实验室第一次考核改错

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

实验室第一次考核改错

大一第一次考核改错 双向链表
//在双向链表指针p的指针前插入一个指针q的结点
q->next = p;
q->prior = p->prior;
p->prior->next = q;
p->prior = q;

双向链表的链接基本可以总结为先处理好要插入的结点的前驱和后继,然后处理和前后结点的链接,题目不是很难,因为熟练度不足,导致了一些不应该的错误

转义字符

emmm,也许是因为脑子短路吧,\输出的是,因为转义字符前都有一个,如果想单独输出一个的话就需要前面加个,不然编译器会一直寻找后面的转义字符,会有比较离奇的一些bug

二维数组
int main(void)	
{
	int a[3][2] = { (0,1),(2,3),(4,5) };
	int* p;
	p = a[0];
	printf("%d", p[0]);

	return 0;
}

如果没看清将()看成{}的话,就有这个题的误会了,因为这里看似是给两个不同的空间分别赋值,实际上是给同一个空间赋值赋值了两次,所以其实覆盖了前面的值

a[0][0]里面的值是1;
a[0][1]里面就是垃圾值了
int main(void)
{
	int a[5] = { 1,2,3,4,5 };
	int* ptr = (int*)(&a + 1);
	pirntf("%d %d", *(a + 1), *(ptr - 1));

	return 0;
}

先取地址,因为是int类型,所以执行+1是在数组的基础上增加,此时指向的空间是a最后一个元素的下一个元素,-1后解引用输入数组的最后一个元素。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/648462.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号