大一第一次考核改错
双向链表
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后解引用输入数组的最后一个元素。
|