//在双向链表指针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后解引用输入数组的最后一个元素。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)