c语言中,一个已定义的指针变量被置空后是如何"记得"它以前所指向的变量的类型的?

如题,比如定义了一个整型的指针p指向整型变量a :
int *p = &a ;
然后将p置空:p = null;
这个时候指针p中所存放的数据即地址已经被清空了,但是再次http://ask.csdn.net/#使用p时还是只能
将其指向整型类型的变量,而不能指向其他类型的变量(比如字符型变量),那么p是
怎么"记得"它在被定义时候的类型的?它的值不是已经被清零了吗?
求大神解答!

3个回答

它被定义为整型指针后就只能指向整型变量,因为地址的分配模式是不一样的,比如整型指针只有32位可以储存,它就无法指向一个地址长度为64位的变量

只是值清空了,类型并不能改变。就像你定义一个整型变量,不管对它进行了什么操作,它始终只能存在整型常量。

1.你名声是 int 指针,永远是;不会变
2.p = null,只是把地址批和null; 不影响类型;类似于,你把一个硬盘的东西清空了,它还是硬盘,不会变成内存,cpu,它的属性不会变化;

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
有哪位大佬能告诉我在C语言中 指针变量 可以被static修饰吗?

就是在C语言中可不可以有"static int* p ;"这种方式定义指针变量。 如果可以效果是不是跟正常的静态变量"static int a;"一样?

C语言中,对函数指针的定义和赋值

设有以下函数    void fun(int n,char * s) {……}  则下面对函数指针的定义和赋值均是正确的是 A)void (*pf)(); pf=fun;  B)void *pf(); pf=fun;  C)void *pf(); *pf=fun;  D)void (*pf)(int, char*);pf=&fun; 自己选的C 正确吗

C语言 static定义变量的问题

static定义一个变量到底需不需要加上数据类型呢?这里没加也没出错 #include<stdio.h> int main() { int i; static a=1; for(i=0;i<5;i++) a=a+i; printf("%d\n",a); } ![图片说明](https://img-ask.csdn.net/upload/201710/15/1508049072_132357.png)

定义一个指向 char 的指针数组?

定义一个指向 char 的指针数组 , 其中数组的每一个元素均是指向字符串的指针,同时定义一个 char 型的双重指针变量;利用双重指针进行 char 型指针数组中字符串的顺序输出。 解题思路:利用双重指针中指针变量与 char 型指针数组的关系进行输出。 参考代码: #include "stdio.h" #include "malloc.h" #include "string.h" #define NUM 1 struct STUDENT { char STU_ID[8]; char STU_NAME[10]; int STU_AGE; int STU_SCORE; }; int main(int argc, char* argv[]) { int i; // 定义由 3 个元素构成的数组,每个元素都是指针,此处将每个指针指向一个常亮字符串 char *CS[3] = {"Follow me","Roger that","Go Go Go"}; char **p; // 双重指针 // 在此处添加 for 循环,使用指针数组 CS 依次打印字符串,每行打印一个 for(i=0; i<3; i++) { // 学生补充代码 // 将数组中的信息赋值给指针,便于通过指针打印字符串信息 { }//end of 学生补充代码 printf("%s\n", *p); } return 1; }

c语言 为什么函数可以返回了一个局部指针结构体?

c语言的里,在函数内部定义的局部指针变量是不能作为返回值的,但我在函数内部定义了一个局部的指针结构体,最后可以返回,这是为什么? 附上代码: ``` c Node_t * ReverseList(Node_t *head) { Node_t *pPrev = NULL; Node_t *next = NULL; head = head->pNext; while (head != NULL) { next = head->pNext; head->pNext = pPrev; pPrev = head; head = next; } head = pPrev; printf("head in fun :%x",head); return pPrev; } ``` 这是一个将单链表反转的函数

C语言中多文件的全局变量声明问题

具体问题请麻烦看链接 [C语言遇到问题](http://blog.csdn.net/u013610563/article/details/50727619 "") 我写了一个函数void match(char* list)/*作用是在list字符串中查找给定子字符串*/ 又写了一个函数void find(void (*match)(char*))/*因为想用函数指针,就把match函数传递进去了 然后find()函数遍历字符串数组。 最后在main()函数中写字符串数组char* shuzu[]的具体内容 然后把match函数,find函数,main函数保存在不同的.c文件中 最后写了一个头文件,其中保存了函数申明,还有那个字符串数组的申明 我是这样写的extern char* shuzu[]; 最后遇到的问题是编译时告诉我find()函数遇到未定义变量shuzu[],,可我不是把它定义成 全局变量保存在头文件中了吗?

定义一个整型的一维数组,并定义一个一维的学生信息结构体数组?

定义一个整型的一维数组,并定义一个一维的学生信息结构体数组,设计一个函数,按照数组下标的顺序,将整型数组中的变量信息赋值给学生结构体数组中的成绩成员变量。要求使用结构体指针类型的变量,进行结构体变量的赋值操作。 解题思路:采用 malloc 函数进行学生结构体指针变量的定义,将结构体指针变量指向学生结构体数组变量的首地址,并使用 --> 访问成员变量的方式进行结构体变量赋值。提示:指针变量指向结构体变量的首地址后,可以使用 ++ 运算符进行指针的移动操作。 参考代码: #include "stdio.h" #include "malloc.h" #include "string.h" #define NUM 1 struct STUDENT { char STU_ID[8]; char STU_NAME[10]; int STU_AGE; int STU_SCORE; }; int main(int argc, char* argv[]) { int i; int Age[5];// 待输入的 5 个年龄 printf(" 请输入五个年龄,以逗号隔开 \n"); // 依次输入 5 个年龄 scanf("%d,%d,%d,%d,%d",&Age[0],&Age[1],&Age[2],&Age[3],&Age[4]); // 定义由 5 个结构体指针构成的数组(相当于 5 个指针) struct STUDENT (*p_stu)[5] = (struct STUDENT (*)[5])malloc(5*sizeof(struct STUDENT)); // 学生补充代码,将数组 Age 中的值依次赋给结构体 { }//end of 学生补充代码 // 打印赋值后的结果 for(i=0; i<5; i++) { printf("%d\n", p_stu[i]->STU_AGE); } return 1; }

关于指针全局变量和局部变量存储位置的问题

想问一下,修改下面代码中的全局变量后,在打印pstr变量时,为什么在反汇编代码中看到callq 5e0 <__stack_chk_fail@plt>(栈检查失败),这是pstr的地址指向出现了问题吗,求大佬详细地解答 ``` #include <stdio.h> #include <stdlib.h> #include <string.h> char cstr[100]="xyz"; char *pstr="xyz"; int main() { char id[100]="123456"; strcpy(cstr,id); strcpy(pstr,id); printf("%s\n",cstr); printf("%s\n",pstr); return 0; } ```

c语言链表指针的指针问题

想问一下那个插入函数的类型是结构体指针的指针,输入参数是一个空指针的地址,有没有大神解释一下这个函数如何使用的呢? 还有就是如果直接用结构体指针函数,应该如何改能实现一样的功能 //学生结构体,包含数据:学号、姓名、性别、毕业学校、初试分数、复试分数 //按照学号递增插入信息 //按照学生姓名查询学号和成绩 #include <stdio.h> #include <stdlib.h> #include <string.h> // 数组结构体 typedef struct Node { int num; char name[20]; char sex[10]; char graduate_scholl[20]; int initial_score; int re_score; struct Node *next; }NODE , *PNODE; //NODE为结构体变量名,指向结构的指针 /* 相当于 typedef struct Node { ...... }NODE; //使用typedef关键字用一个单词NODE代替struct TreeNode,并定于指向该结构体类型的指针PNODE: NODE *PNODE; */ /** * 插入数字 * @param ** head 头指针地址 * @param int value 插入的数值 * @return void */ PNODE * insertValue(PNODE*head); /** * 打印数组 * @param * head 头指针 * @return void */ void printfValue(PNODE head); void check(PNODE head);//查询函数 int main(void) { PNODE head = NULL; int index; do { printf("是否录入学生数据?(0否/1是):"); scanf("%d", &index); if (index == 1) { insertValue(&head);//这里为何要这样取空指针 printf("\n\n"); printfValue(head); } } while (index == 1); check(head); return 0; } PNODE *insertValue(PNODE *head) //就是这个函数 看了好几天都没太懂 { PNODE previous = NULL; // 前一个指向地址 PNODE current = *head; // 当前指向地址 PNODE pNew = (PNODE )malloc(sizeof( NODE)); if (pNew == NULL) { printf("申请内存失败"); exit(1); } else { printf("请输入学生学号:"); scanf("%d",&pNew->num); printf("请输入学生姓名:"); scanf("%s",pNew->name); printf("请输入学生性别:"); scanf("%s",pNew->sex); printf("请输入学生毕业学校:"); scanf("%s",pNew->graduate_scholl); printf("请输入学生初试分数:"); scanf("%d",&pNew->initial_score); printf("请输入学生复试分数:"); scanf("%d",&pNew->re_score); } // currnt 不为 NULL => 数组有值 // current的值 < 待插入的值 => 转到下一个指向地址,并把当前地址存入previous。 while (current != NULL && current -> num < pNew -> num) { previous = current; //往后遍历,直到插入的值不大于当前的数 current = current -> next; } // 下一个地址内的值 > 待插入的值 => 待插入的值插入previous和current之间 pNew -> next = current; if (previous == NULL) { // previous == NULL 说明没有执行遍历循环 // 头插法 *head = pNew; } else { // previous(next) -> pNew(next) -> current previous -> next = pNew;//待插入的值插入previous之后 } return head; } void check(PNODE head) { char temp[10]; PNODE p=head; if(NULL == p) { printf("未录入信息,信息查询失败!"); } else { printf("请输入需要查询考生姓名:"); scanf("%s",temp) ; } while(p != NULL) { if(!strcmp(p->name,temp)) { printf("\n考生姓名为:%s的信息如下:\n",p->name); printf("该学生的学号为:%d\n",p->num); printf("该考生的初试成绩为:%d\n",p->initial_score); printf("该考生的复试成绩为:%d\n",p->re_score); break; } p = p->next; } } void printfValue(PNODE head) { PNODE current = head; while (current != NULL) { printf("学号:%d\n",current->num); printf("姓名:%s\n",current->name); printf("性别:%s\n",current->sex); printf("毕业学校:%s\n",current->graduate_scholl); printf("初试分数:%d\n",current->initial_score); printf("复试分数:%d\n",current->re_score); printf("\n"); current = current -> next; } printf("\n"); }

结构体指针成员变量在赋值后被篡改了是怎么回事?

结构体指针地址没变,值被篡改了什么情况,有没有大神知道啊 // ConsoleApplication1.cpp : 定义控制台应用程序的入口点。 // #include "stdafx.h" #include "iostream" #include "string.h" using namespace std; struct STU_LIST { char name[40]; int num; char sex[4]; int clas; struct STU_LIST *nex; }; /******************************************************************************************************************/ /*------------------------------------ -----数字提取------------ ---------------------------------------------*/ /******************************************************************************************************************/ int strEint(const char *str) { int len = strlen(str),i,num; char *tepnum,*tep; tepnum = new char[40]; tep=tepnum; i=len-1; *(tepnum+len) = '\0'; while (i>=0) { if (*(str+i)>='0'&&*(str+i)<='9') { *(tepnum+i)=*(str+i); } else { tepnum=tepnum+i+1; i=0; } i--; } num = atoi(tepnum); delete[] tep; return num; } struct STU_LIST *STU_insirt(struct STU_LIST *head,int n); struct STU_LIST *PRESENT_class; /******************************************************************************************************************/ /*------------------------------------ -----主程序------------ -------------------------------------------------*/ /******************************************************************************************************************/ int _tmain(int argc, _TCHAR* argv[]) { char *comad; int lep = -1; bool state = true,create_sign = false; comad = new char; cout<<"欢迎使用学生名单录入工具,请输入命令命令进行操作。\n输入help查询可用命令。"<<endl; PRESENT_class = new struct STU_LIST; PRESENT_class->clas = 10; PRESENT_class->num = 0; PRESENT_class->nex = NULL; while (state) { cin>>comad; int nums; struct STU_LIST *temp; nums = strEint(comad); if (nums <= 0) { cout<<"您的操作命令缺少有效参数或参数类型有误!!!"<<endl; cout<<"您可以输入help来查询可用操作命令,及使用格式和方法。"<<endl; } else { if(PRESENT_class != NULL) { temp = STU_insirt(PRESENT_class,nums); cout<<"temp->nex->"<<static_cast<const void *>(temp->nex)<<endl; cout<<"temp->nex->num->"<<static_cast<const void *>(&temp->nex->num)<<endl; cout<<temp->clas<<"班"<<temp->name<<"的信息记录已添加。"<<endl; if (temp->nex == NULL) { cout<<"本节点是尾结点"<<endl; } else { cout<<"头节点的学号是"<<temp->num<<endl; cout<<"第二个节点的学号是"<<temp->nex->num<<endl; } } else { cout<<"您要往哪个班级添加学生信息,请在添加信息前先选择一个班级的登记表。"<<endl; cout<<"您可以输入help来查询可用操作命令,及使用格式和方法。"<<endl; } } if (strstr(comad,"exit")!=NULL) { state = false; } } return 0; } /******************************************************************************************************************/ /*-----------------------------------------插入学生条目-----------------------------------------------------------*/ /******************************************************************************************************************/ struct STU_LIST *STU_insirt(struct STU_LIST *head,int n) { struct STU_LIST *temp,*stp1,*lastsp; temp = head; lastsp = NULL; bool sign = true; while (sign) { cout<<"当前节点学号是"<<temp->num<<endl; if(temp->num >= n) //假如要插入的学号不大于当前节点学号 { if(temp->num > n ) //假如要插入的学号小于当前节点学号,那么在当前节点前面创建新节点并录入学生数据 { stp1=(struct STU_LIST*) alloca(sizeof(struct STU_LIST)); stp1->num = n; stp1->clas = head->clas; cout<<"请输入学生姓名:"; cin >>stp1->name; cout<<"请输入学生性别:"; cin >>stp1->sex; stp1->nex = temp; if(temp == head ) //假如当前节点是头结点,那么设置新节点为表头 { head = stp1; sign = false; } else //假如当前节点不是头结点,将上一个节点的指针指向新节点,跳出循环结束命令 { lastsp->nex = stp1; sign = false; } } else //假如要插入的学号等于当前节点学号,那么更新该节点学生数据。 { cout<<"请输入学生姓名:"; cin >>temp->name; cout<<"请输入学生性别:"; cin >>temp->sex; sign = false; } } else //假如要插入的学号大于当前节点学号 { cout<<"要插入的节点大于当前节点"<<endl; if(temp->num == 0) //假如当前节点学号等于0,意味着当前节点没有录入过数据,那么将本节点作为插入的节点录入学生数据。 { temp->num = n; cout<<"请输入学生姓名:"; cin >>temp->name; cout<<"请输入学生性别:"; cin >>temp->sex; temp->nex = NULL; sign = false; } else //假如当前节点的学号不等于0。 { if(temp->nex == NULL) //假如当前节点是尾结点,那么在当前节点之后创建新节点 { stp1 = (struct STU_LIST*) alloca(sizeof(struct STU_LIST)); cout<<"stp1 -> "<<static_cast<const void *>(stp1)<<endl; stp1->num = n; cout<<"新节点的学号是"<<stp1->num<<endl; stp1->clas = head->clas; stp1->nex = NULL; cout<<"请输入学生姓名:"; cin >>stp1->name; cout<<"请输入学生性别:"; cin >>stp1->sex; temp->nex = stp1; cout<<"temp->nex->num="<<temp->nex->num<<endl; cout<<"temp->nex->num->"<<static_cast<const void *>(&temp->nex->num)<<endl; sign = false; } else //假如当前节点不是尾结点,那么将当前节点设置为下个节点 { lastsp = temp; temp = temp->nex; } } } } if(head->nex != NULL) { cout<<"head->nex->num="<<head->nex->num<<endl; cout<<"head->nex->num->"<<static_cast<const void *>(&head->nex->num)<<endl; } return head; } ![图片说明](https://img-ask.csdn.net/upload/201912/28/1577541877_870062.png) 在函数内部时候值不变,一出函数内存里的值就变了这是什么道理。

c语言,为什么我定义了一个全局变量,总是会自动变为零?

``` #include<stdio.h> #include<stdlib.h> #include<string.h> #include<time.h> #include<conio.h> int score=0,move=0,a[4][4]={0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0},temp[5],highest_score=0; void print(void) { int i,j; system("cls"); printf(" ___________________2048________________\n"); printf(" ------------how to play?----------\n"); printf(" A---left,D-right,W---up,S---down,0---exit\n"); printf(" ----------------------------------\n"); printf(" highest score:%d\n",highest_score); printf(" ----------------------------------\n"); printf(" score:%d move:%d \n",score,move); for(i=0;i<4;i++) { printf(" |-------------------|\n"); printf(" "); for(j=0;j<4;j++) { if(a[i][j]==0) printf("| "); else printf("|%-4d",a[i][j]); if(j==3) printf("|\n"); } } printf(" |-------------------|\n"); } int add() { int i,j,t=1,change=0; while(t<=3) { for(i=0;i<3;i++) { if(temp[i]==0) { if(temp[i]!=temp[i+1]) change=1; temp[i]=temp[i+1]; temp[i+1]=0; } } t++; } for(i=0;i<3;i++) { if(temp[i]==temp[i+1]) { if(temp[i]!=0) { change=1; score=score+temp[i]; } temp[i]=temp[i]*2; temp[i+1]=0; } } t=1; while(t<=3) { for(i=0;i<3;i++) { if(temp[i]==0) { temp[i]=temp[i+1]; temp[i+1]=0; } } t++; } return change; } int main() { int change=1,gameover=0,i,j; char input; srand((unsigned)time(NULL)); while(gameover==0) { if(change>=1) { do { i=((unsigned)rand())%4; j=((unsigned)rand())%4; }while(a[i][j]!=0); if(((unsigned)rand())%2==0) a[i][j]=2; else a[i][j]=4; } print(); input=getch(); change=0; if(input=='0') { printf("Do you really want to exit this game?Y/N\n"); input=getch(); if(input=='y'||input=='Y') break; } else if(input=='w'||input=='W') { for(j=0;j<4;j++) { for(i=0;i<4;i++) temp[i]=a[i][j]; temp[5]=0; change+=add(); for(i=0;i<4;i++) a[i][j]=temp[i]; } move++; } else if(input=='s'||input=='S') { for(j=0;j<4;j++) { for(i=0;i<4;i++) temp[i]=a[3-i][j]; temp[5]=0; change+=add(); for(i=0;i<4;i++) a[i][j]=temp[3-i]; } move++; } else if(input=='a'||input=='A') { for(i=0;i<4;i++) { for(j=0;j<4;j++) temp[j]=a[i][j]; temp[5]=0; change+=add(); for(j=0;j<4;j++) a[i][j]=temp[j] ; } move++; } else if(input=='d'||input=='D') { for(i=0;i<4;i++) { for(j=0;j<4;j++) temp[j]=a[i][3-j]; temp[5]=0; change+=add(); for(j=0;j<4;j++) a[i][j]=temp[3-j]; } move++; } gameover=1; for(i=0;i<4;i++) for(j=0;j<4;j++) { if(a[i][j]==0) gameover=0; } if(gameover==1) { for(i=0;i<3;i++) for(j=0;j<3;j++) if(a[i][j]==a[i+1][j]||a[i][j]==a[i][j+1]) gameover=0; for(i=0;i<3;i++) if(a[3][i]==a[3][i+1]||a[i][3]==a[i+1][3]) gameover=0; } if(gameover==1) { printf("Do you want to try again?Y/N"); input=getch(); if(input=='Y'||input=='y') { gameover=0; memset(a,0,sizeof(a)); change=1; if(score>highest_score) highest_score=score; score=0; move=0; } else if(input=='n'||input=='N') gameover=1; } } printf("\n Game over!\n"); getch(); return 0; } ``` 就是highest_score这个全局变量,为什么每次重新开始游戏的时候只在按过Y之后才会显示为score的值,之后一旦进行了一次操作,就右边为了0?而且我发现只要把它改为一个非零的数,就一切正常,这是为什么?

c语言中,为什么不能对字符指针变量指向的字符串再赋值?

比如说这段: char *a="hello"; a[2]='c'; //就是这个语句为什么不正确啊

C语言求解,简单问题求解

在C语言里,定义整型变量a可以使用语句: int a; 而定义一重指针变量p1指向a变量,即把a变量的地址储存在指针变量p1里,可以使用语句: int *p1; p1 = &a; 若要通过p1访问变量a,应该使用: *p1 定义二重变量p2指向p1指针,即把p1的地址存储在p2里,可以使用: int *p2; p2 = &p1; 由于p1之前已经指向a,因此通过p2可以访问到a变量,使用: **p2 以此类推...... 现在给出一个x重指针变量的定义,并假设之前已经定义过1重,2重,...,x-1重指针变量,而且已经将1重指针变量指向a变量,2重指针指向1重指针,...,x重指针指向x-1重指针。 问如何通过x重指针访问变量a? 输入 输入数据有多组,每组只描述x重指针变量的定义,定义格式为: intX Y; 其中X为若干个*,Y遵守C语言标识符命名规则。每行总长度不超过100个字符。 输入直到文件结束为止。 输出 每组输出一行,每行输出一串字符,表示如何通过定义的指针访问a变量,不留空格。 样例输入 int* p; int** prr; int**** yyy; 样例输出 *p **prr ****yyy 我的代码 #include<stdio.h> int main() { char str[101]; char* p; int i; while(scanf("%c",str)!=EOF) { for(i=1;*(str+i)=getchar(),str[i]!=';';i++); str[i]='\0'; for(i=0;*(str+i)!='*';i++); for(;*(str+i)=='*';i++) { putchar('*'); } for(;*(str+i)==' ';i++); printf("%s\n",str+i); } return 0; } 哪里错了

c语言指针直接赋值问题

为什么我用了强制转换还会出现这些问题,而且为什么每次运行,a的地址都不一样的 ``` #include<stdio.h> #include<stdlib.h> void main() { int *p=NULL; int a = 10; printf("%d\n", &a); p =(int *) 0x0047abc; *p = 20; printf("%d", a); } ``` ![图片说明](https://img-ask.csdn.net/upload/201701/30/1485739801_263070.png)

C语言中指向字符串的指针的赋值方式

``` char ch[10] = "abcdefg"; char* p1 = ch; char* p2 = "hijklmn"; //这种赋值方式符合规范吗? puts(p1); //正常输出abcdefg puts(p2); //正常输出hijklmn p1[2] = p2[2]; puts(p1); //输出abjdefg p2[3] = p1[3]; puts(p2); //无法输出,程序在上一条语句终止,且不报错 ``` 大家知道怎么回事吗??

设计一个函数,能够对输入的两个学生结构体信息中的成绩按照大小顺序输出。要求使用指针类型的变量进行结构体变量的定义?

设计一个函数,能够对输入的两个学生结构体信息中的成绩按照大小顺序输出。要求使用指针类型的变量进行结构体变量的定义。 解题思路:采用 malloc 函数进行结构体指针变量的定义,并使用 --> 访问成员变量的方式进行结构体变量赋值;比较两个结构体信息中学生的成绩成员变量的大小,按照大小顺序输出。 参考代码: #include "stdio.h" #include "malloc.h" #include "string.h" #define NUM 1 struct STUDENT { char STU_ID[8]; char STU_NAME[10]; int STU_AGE; int STU_SCORE; }; int main(int argc, char* argv[]) { struct STUDENT *stu1 = (struct STUDENT *)malloc(sizeof(struct STUDENT)); stu1->STU_AGE=12; strcpy(stu1->STU_ID,"04120084"); strcpy(stu1->STU_NAME," 张三 "); struct STUDENT *stu2=(struct STUDENT *)malloc(sizeof(struct STUDENT)); stu2->STU_AGE=12; strcpy(stu2->STU_ID,"04120085"); strcpy(stu2->STU_NAME," 李四 "); printf(" 输入学生成绩 \n"); scanf("%d,%d",&(stu1->STU_SCORE),&(stu2->STU_SCORE)); // 学生补充代码 { }//end of 补充代码 printf("%s,%d\n",stu1->STU_NAME,stu1->STU_SCORE); printf("%s,%d\n",stu2->STU_NAME,stu2->STU_SCORE); return 1; }

C语言中结构体先声明后定义不可以吗?

C语言中结构体先声明后定义不可以吗? 我几次测过了,把结构体放在主函数前正常运行,把结构体放在结构体后面就用不了了,求各位帮我解释一下。

C语言 字符串指针排序函数

下面这个是用冒泡排序,运行错误 ``` #include<stdio.h> #include<string.h> #define N 5 int main() { char ptr[N][80]={ "how ","are ","you ","i","fine" }; char *p[N]; char *temp; int i,j; for(i=0;i<N;i++) p[i]=ptr[i]; for(i=0;i<N-1;i++) for(j=0;j<N-i;j++) if(strcmp(p[j],p[j+1])>0) { temp=p[j]; p[j]=p[j+1]; p[j+1]=temp; } for(i=0;i<N;i++) puts(p[i]); } ``` 下面这个是用选择排序,运行结果却是正确的 ``` #include<stdio.h> #include<string.h> #define N 5 int main() { char ptr[N][80]={ "how ","are ","you ","i","fine" }; char *p[N]; char *temp; int i,j; for(i=0;i<N;i++) p[i]=ptr[i]; for(i=0;i<N-1;i++) for(j=i+1;j<N;j++) if(strcmp(p[i],p[j])>0) { temp=p[j]; p[j]=p[i]; p[i]=temp; } for(i=0;i<N;i++) puts(p[i]); } ``` 下面这个没有用指针,直接改变原字符串数组,是用冒泡排序 也是正确的 ``` #include<stdio.h> #include<string.h> #define N 5 int main() { char ptr[N][80]={ "how ","are ","you ","i","fine" }; char temp[80]; int i,j; for(i=0;i<N-1;i++) for(j=0;j<N-i;j++) if(strcmp(ptr[j],ptr[j+1])>0) { strcpy(temp,ptr[j]); strcpy(ptr[j],ptr[j+1]); strcpy(ptr[j+1],temp); } for(i=0;i<N;i++) puts(ptr[i]); } ``` 求解答,万分感谢!

初学二叉树的初始化,为什么一定要定义一个指针型变量

根据视屏教程里的代码,第八行结构后定义了一个(星号)BiTree,但是程序里的所有二级指针变量前都加了取值符合(星号),不知道为什么要定义这个指针型的(星号)BiTree,于是稍作修改,将去掉并且整个程序只有一级指针,但是运行出错 请问原因是什么? ``` //以下是教学上的正确代码 #include <stdio.h> #include <stdlib.h> typedef char elemtype; typedef struct BiTNode { char data; struct BiTNode *lchild,*rchild; }BiTNode,*BiTree; //创建一颗二叉树,约定用户用前序遍历方式输入数据 void createBiTree(BiTree *T) { char c; scanf("%c",&c); if(' '==c) { *T=NULL; } else { *T=(BiTNode*)malloc(sizeof(BiTNode)); (*T)->data=c; createBiTree(&(*T)->lchild); createBiTree(&(*T)->rchild); } } void visit(char c,int level)//访问二叉树节点的具体操作 { printf("%c位于第%d层\n",c,level); } //前序遍历二叉树 void PreOrderTraverse(BiTree T,int level) { if(T) { visit(T->data,level); PreOrderTraverse(T->lchild,level+1); PreOrderTraverse(T->rchild,level+1); } } int main(int argc, char *argv[]) { int level=1; BiTree T=NULL; createBiTree(&T); PreOrderTraverse(T,level); return 0; } //********************** //********************** //********************** //以下为修改后不能正常运行的代码 #include <stdio.h> #include <stdlib.h> typedef char elemtype; typedef struct BiTNode { char data; struct BiTNode *lchild,*rchild; }BiTree; void createBiTree(BiTree *T) { char c; scanf("%c",&c); if(' '==c) { T=NULL; } else { T=(BiTree*)malloc(sizeof(BiTree)); T->data=c; createBiTree(T->lchild); createBiTree(T->rchild); } } void visit(char c,int level)//访问二叉树节点的具体操作 { printf("%c位于第%d层\n",c,level); } //前序遍历二叉树 void PreOrderTraverse(BiTree *T,int level) { if(T) { visit(T->data,level); PreOrderTraverse(T->lchild,level+1); PreOrderTraverse(T->rchild,level+1); } } int main(int argc, char *argv[]) { int level=1; BiTree T; createBiTree(&T); PreOrderTraverse(&T,level); return 0; } ```

大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了

大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...

在中国程序员是青春饭吗?

今年,我也32了 ,为了不给大家误导,咨询了猎头、圈内好友,以及年过35岁的几位老程序员……舍了老脸去揭人家伤疤……希望能给大家以帮助,记得帮我点赞哦。 目录: 你以为的人生 一次又一次的伤害 猎头界的真相 如何应对互联网行业的「中年危机」 一、你以为的人生 刚入行时,拿着傲人的工资,想着好好干,以为我们的人生是这样的: 等真到了那一天,你会发现,你的人生很可能是这样的: ...

程序员请照顾好自己,周末病魔差点一套带走我。

程序员在一个周末的时间,得了重病,差点当场去世,还好及时挽救回来了。

技术大佬:我去,你写的 switch 语句也太老土了吧

昨天早上通过远程的方式 review 了两名新来同事的代码,大部分代码都写得很漂亮,严谨的同时注释也很到位,这令我非常满意。但当我看到他们当中有一个人写的 switch 语句时,还是忍不住破口大骂:“我擦,小王,你丫写的 switch 语句也太老土了吧!” 来看看小王写的代码吧,看完不要骂我装逼啊。 private static String createPlayer(PlayerTypes p...

上班一个月,后悔当初着急入职的选择了

最近有个老铁,告诉我说,上班一个月,后悔当初着急入职现在公司了。他之前在美图做手机研发,今年美图那边今年也有一波组织优化调整,他是其中一个,在协商离职后,当时捉急找工作上班,因为有房贷供着,不能没有收入来源。所以匆忙选了一家公司,实际上是一个大型外包公司,主要派遣给其他手机厂商做外包项目。**当时承诺待遇还不错,所以就立马入职去上班了。但是后面入职后,发现薪酬待遇这块并不是HR所说那样,那个HR自...

女程序员,为什么比男程序员少???

昨天看到一档综艺节目,讨论了两个话题:(1)中国学生的数学成绩,平均下来看,会比国外好?为什么?(2)男生的数学成绩,平均下来看,会比女生好?为什么?同时,我又联想到了一个技术圈经常讨...

为什么本科以上学历的人只占中国人口的5%,但感觉遍地都是大学生?

中国大学生占总人口不到5% 2017年,中国整体的本科率仅有5.9%;如果算上研究生,这一比例可以进一步上升到6.5% 为什么在国家统计局推出的这份年鉴中,学历的最高一阶就是到研究生,而没有进一步再统计博士生的数量的。 原因其实并不难理解,相比全国和各省整体人口体量,博士生的占比非常之低,属于绝对意义上的小概率样本。 这一点,我们从上表中的各省研究生占比情况也可以看出端倪。除北京、天津、上海三...

副业收入是我做程序媛的3倍,工作外的B面人生是怎样的?

提到“程序员”,多数人脑海里首先想到的大约是:为人木讷、薪水超高、工作枯燥…… 然而,当离开工作岗位,撕去层层标签,脱下“程序员”这身外套,有的人生动又有趣,马上展现出了完全不同的A/B面人生! 不论是简单的爱好,还是正经的副业,他们都干得同样出色。偶尔,还能和程序员的特质结合,产生奇妙的“化学反应”。 @Charlotte:平日素颜示人,周末美妆博主 大家都以为程序媛也个个不修边幅,但我们也许...

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

如果你是老板,你会不会踢了这样的员工?

有个好朋友ZS,是技术总监,昨天问我:“有一个老下属,跟了我很多年,做事勤勤恳恳,主动性也很好。但随着公司的发展,他的进步速度,跟不上团队的步伐了,有点...

我入职阿里后,才知道原来简历这么写

私下里,有不少读者问我:“二哥,如何才能写出一份专业的技术简历呢?我总感觉自己写的简历太烂了,所以投了无数份,都石沉大海了。”说实话,我自己好多年没有写过简历了,但我认识的一个同行,他在阿里,给我说了一些他当年写简历的方法论,我感觉太牛逼了,实在是忍不住,就分享了出来,希望能够帮助到你。 01、简历的本质 作为简历的撰写者,你必须要搞清楚一点,简历的本质是什么,它就是为了来销售你的价值主张的。往深...

程序员写出这样的代码,能不挨骂吗?

当你换槽填坑时,面对一个新的环境。能够快速熟练,上手实现业务需求是关键。但是,哪些因素会影响你快速上手呢?是原有代码写的不够好?还是注释写的不够好?昨夜...

外包程序员的幸福生活

今天给你们讲述一个外包程序员的幸福生活。男主是Z哥,不是在外包公司上班的那种,是一名自由职业者,接外包项目自己干。接下来讲的都是真人真事。 先给大家介绍一下男主,Z哥,老程序员,是我十多年前的老同事,技术大牛,当过CTO,也创过业。因为我俩都爱好喝酒、踢球,再加上住的距离不算远,所以一直也断断续续的联系着,我对Z哥的状况也有大概了解。 Z哥几年前创业失败,后来他开始干起了外包,利用自己的技术能...

带了6个月的徒弟当了面试官,而身为高级工程师的我天天修Bug......

即将毕业的应届毕业生一枚,现在只拿到了两家offer,但最近听到一些消息,其中一个offer,我这个组据说客户很少,很有可能整组被裁掉。 想问大家: 如果我刚入职这个组就被裁了怎么办呢? 大家都是什么时候知道自己要被裁了的? 面试软技能指导: BQ/Project/Resume 试听内容: 除了刷题,还有哪些技能是拿到offer不可或缺的要素 如何提升面试软实力:简历, 行为面试,沟通能...

优雅的替换if-else语句

场景 日常开发,if-else语句写的不少吧??当逻辑分支非常多的时候,if-else套了一层又一层,虽然业务功能倒是实现了,但是看起来是真的很不优雅,尤其是对于我这种有强迫症的程序"猿",看到这么多if-else,脑袋瓜子就嗡嗡的,总想着解锁新姿势:干掉过多的if-else!!!本文将介绍三板斧手段: 优先判断条件,条件不满足的,逻辑及时中断返回; 采用策略模式+工厂模式; 结合注解,锦...

离职半年了,老东家又发 offer,回不回?

有小伙伴问松哥这个问题,他在上海某公司,在离职了几个月后,前公司的领导联系到他,希望他能够返聘回去,他很纠结要不要回去? 俗话说好马不吃回头草,但是这个小伙伴既然感到纠结了,我觉得至少说明了两个问题:1.曾经的公司还不错;2.现在的日子也不是很如意。否则应该就不会纠结了。 老实说,松哥之前也有过类似的经历,今天就来和小伙伴们聊聊回头草到底吃不吃。 首先一个基本观点,就是离职了也没必要和老东家弄的苦...

记录下入职中软一个月(外包华为)

我在年前从上一家公司离职,没想到过年期间疫情爆发,我也被困在家里,在家呆着的日子让人很焦躁,于是我疯狂的投简历,看面试题,希望可以进大公司去看看。 我也有幸面试了我觉得还挺大的公司的(虽然不是bat之类的大厂,但是作为一名二本计算机专业刚毕业的大学生bat那些大厂我连投简历的勇气都没有),最后选择了中软,我知道这是一家外包公司,待遇各方面甚至不如我的上一家公司,但是对我而言这可是外包华为,能...

为什么程序员做外包会被瞧不起?

二哥,有个事想询问下您的意见,您觉得应届生值得去外包吗?公司虽然挺大的,中xx,但待遇感觉挺低,马上要报到,挺纠结的。

当HR压你价,说你只值7K,你该怎么回答?

当HR压你价,说你只值7K时,你可以流畅地回答,记住,是流畅,不能犹豫。 礼貌地说:“7K是吗?了解了。嗯~其实我对贵司的面试官印象很好。只不过,现在我的手头上已经有一份11K的offer。来面试,主要也是自己对贵司挺有兴趣的,所以过来看看……”(未完) 这段话主要是陪HR互诈的同时,从公司兴趣,公司职员印象上,都给予对方正面的肯定,既能提升HR的好感度,又能让谈判气氛融洽,为后面的发挥留足空间。...

面试:第十六章:Java中级开发

HashMap底层实现原理,红黑树,B+树,B树的结构原理 Spring的AOP和IOC是什么?它们常见的使用场景有哪些?Spring事务,事务的属性,传播行为,数据库隔离级别 Spring和SpringMVC,MyBatis以及SpringBoot的注解分别有哪些?SpringMVC的工作原理,SpringBoot框架的优点,MyBatis框架的优点 SpringCould组件有哪些,他们...

面试阿里p7,被按在地上摩擦,鬼知道我经历了什么?

面试阿里p7被问到的问题(当时我只知道第一个):@Conditional是做什么的?@Conditional多个条件是什么逻辑关系?条件判断在什么时候执...

Python爬虫,高清美图我全都要(彼岸桌面壁纸)

爬取彼岸桌面网站较为简单,用到了requests、lxml、Beautiful Soup4

无代码时代来临,程序员如何保住饭碗?

编程语言层出不穷,从最初的机器语言到如今2500种以上的高级语言,程序员们大呼“学到头秃”。程序员一边面临编程语言不断推陈出新,一边面临由于许多代码已存在,程序员编写新应用程序时存在重复“搬砖”的现象。 无代码/低代码编程应运而生。无代码/低代码是一种创建应用的方法,它可以让开发者使用最少的编码知识来快速开发应用程序。开发者通过图形界面中,可视化建模来组装和配置应用程序。这样一来,开发者直...

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

6年开发经验女程序员,面试京东Java岗要求薪资28K

写在开头: 上周面试了一位女程序员,上午10::30来我们部门面试,2B哥接待了她.来看看她的简历: 个人简历 个人技能: ● 熟悉spring mvc 、spring、mybatis 等框架 ● 熟悉 redis 、rocketmq、dubbo、zookeeper、netty 、nginx、tomcat、mysql。 ● 阅读过juc 中的线程池、锁的源...

大三实习生,字节跳动面经分享,已拿Offer

说实话,自己的算法,我一个不会,太难了吧

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

Java岗开发3年,公司临时抽查算法,离职后这几题我记一辈子

前几天我们公司做了一件蠢事,非常非常愚蠢的事情。我原以为从学校出来之后,除了找工作有测试外,不会有任何与考试有关的事儿。 但是,天有不测风云,公司技术总监、人事总监两位大佬突然降临到我们事业线,叫上我老大,给我们组织了一场别开生面的“考试”。 那是一个风和日丽的下午,我翘着二郎腿,左手端着一杯卡布奇诺,右手抓着我的罗技鼠标,滚动着轮轴,穿梭在头条热点之间。 “淡黄的长裙~蓬松的头发...

大牛都会用的IDEA调试技巧!!!

导读 前天面试了一个985高校的实习生,问了他平时用什么开发工具,他想也没想的说IDEA,于是我抛砖引玉的问了一下IDEA的调试用过吧,你说说怎么设置断点...

都前后端分离了,咱就别做页面跳转了!统统 JSON 交互

文章目录1. 无状态登录1.1 什么是有状态1.2 什么是无状态1.3 如何实现无状态1.4 各自优缺点2. 登录交互2.1 前后端分离的数据交互2.2 登录成功2.3 登录失败3. 未认证处理方案4. 注销登录 这是本系列的第四篇,有小伙伴找不到之前文章,松哥给大家列一个索引出来: 挖一个大坑,Spring Security 开搞! 松哥手把手带你入门 Spring Security,别再问密...

立即提问
相关内容推荐