C语言链表插入问题 插入节点到头节点之前去 遍历后发现只能显示插入的那个节点。

#include
#include
#include
#include
struct student{
char name[10];
struct student next;
};
struct student *charu(struct student *p)
{
struct student *current;
struct student *insert;
int a;
insert=(struct student
)malloc(sizeof(struct student));
char name[10];
printf("请输入你要插入的位置:");
scanf("%d",&a);
printf("请输入要插入的字符:\n");
scanf("%s",name);
getchar();
strcpy(insert->name,name);
current=p;
if(a>0)
{}
else if(a==0)
{insert->next=current;
p=insert;
}
return p;
}
void main()
{
struct student head,*non,*end;
char str[10],i,j;
int a;
head=(struct student
)malloc(sizeof(struct student));
printf("请输入名字:\n");
scanf("%s",str);
getchar();
strcpy(head->name,str);
printf("是否要继续输入:");
scanf("%c",&i);
non=head;
while(i!='n')
{
end=(struct student*)malloc(sizeof(struct student));
printf("请输入名字:\n");
scanf("%s",str);
getchar();
strcpy(end->name,str);
non->next=end;
non=end;
printf("是否要继续输入:");
scanf("%c",&i);
}
non->next=NULL;
while(head!=NULL)
{printf("%s\n",head->name);head=head->next;}
getchar();
printf("你是否要插入字符:");
scanf("%c",&j);
if(j=='y')
{
head=charu(head);
printf("插入后的链表为:\n");
while(head!=NULL)
{printf("%s\n",head->name);head=head->next;}
}
}
我插入一个节点第0个位置 就是头结点那个位置 插入完了以后遍历只能显示出第一个节点 这是怎么回事啊请教各位!!

2个回答

struct student *charu(struct student *p) 该处,需要传输的是指针的指针。 具体还需要再调试一下啊。仅传入指针,返回后就不对了。

struct student *charu(struct student **p)
{
struct student *current;
struct student *insert;
int a;
insert=(struct student)malloc(sizeof(struct student));
char name[10];
printf("请输入你要插入的位置:");
scanf("%d",&a);
printf("请输入要插入的字符:\n");
scanf("%s",name);
getchar();
strcpy(insert->name,name);
current=*p;
if(a>0)
{}
else if(a==0)
{insert->next=current;
*p=insert;
}
return p;
}

struct student{
char name[10];
struct student next;
};
应该这样写==》
typedef struct student{
char name[10];
student* next;
} student;

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
c语言链表 插入,dalao进来看看呗

typedef struct book { int number; char name[20]; int jaige; }stumes; typedef struct tagnode { stumes data; struct tagnode *next; }node; node *head=NULL; void charu() { int num,i; node *p,*q; p=head; printf("请输入你要插入位置: "); scanf("%d",&num); { printf("请输入你要插入的:\n"); q=(node *)malloc(sizeof(node)); scanf("%d %s %c %d %d",&q->data.number,q->data.jaige,q->data.name); while(p!=NULL) { if(p->data.number==q->data.number) { printf("该学号已经存在,无法插入!\n"); return ; } p=p->next; } p=head; for(i=0;i<num;i++) p=p->next; q->next=p->next; p->next=q; printf("插入成功!\n"); return ; } } 编译时通过了的,应该是逻辑上出了问题。

c语言链表删除节点问题

#include <stdio.h> #define NUll 0 #include <stdlib.h> struct stu { char name[6]; int xuehao; int grade; struct stu *next; }; typedef struct stu STU; main() { STU *p,*p_start,*p2,*p_print,*p_charu,*p_charu2; int i,xuehao; //输入 for (i=0;i<3;i++) { p=(STU *)malloc(sizeof(STU)); printf("请输入学生姓名:\n"); scanf("%s",&p->name); printf("请输入学生的学号:\n"); scanf("%d",&p->xuehao); printf("请输入学生的成绩:\n"); scanf("%d",&p->grade); if (i==0) p2=p_start=p; else { p2->next=p; p2=p; if (i==2) p->next=NULL; } } // printf("%d",p_start->next->next->next); // printf("%d",p_start->next->next->xuehao); //链表的插入 p_charu=p_start; printf("请输入要删除的学号\n"); scanf("%d",&xuehao); while (1) { p_charu2=p_charu->next; if (p_charu->next->xuehao==xuehao) { // if (p_charu->next->next==NULL) // p_charu->next=NULL; else p_charu->next=p_charu->next->next; free(p_charu2); break; } if (p_charu->xuehao==xuehao) { p_start=p_charu->next; free(p_charu); break; } p_charu=p->next; } //输出 p_print=p_start; /* for (i=0;i<2;i++) { printf("学生姓名为:%s\n",p_print->name); printf("学生的学号为:%d\n",p_print->xuehao); printf("学生的分数为:%d\n",p_print->grade); if (p_print->next!=NULL) p_print=p_print->next; } */ } 这是一个删除结点并输出的程序, 加注释的输出部分没有问题,关键应该在删除结点的循环那里,但是找不见错误啊, 错误为:当删除最后一个链表也就是3时程序发生错误,停止运行。 求解

关于C语言链表插入的问题

``` #include<stdio.h> #include<stdlib.h> struct node { int num; int L; struct node *next; }; typedef struct node LN; LN *Creat(int n); void print(LN *h); void Revise(LN *p); void main() { LN *h; int a; printf("Input the sum of the number:"); scanf("%d",&a); h=Creat(a); system("CLS"); Revise(h); print(h); } LN *Creat(int n) { LN *head; LN *p; LN *b; head=(LN *)malloc(sizeof(LN)); head->next=NULL; b=head; for(int i=1;i<=n;i++) { printf("Input the %d number:",i); p=(LN *)malloc(sizeof(LN)); scanf("%d",&p->num); b->next=p; b=p; p->L++; } system("CLS"); p->next=NULL; return head; } void print(LN *h) { LN *p; p=h->next; while(p) { printf("%d\n",p->num); p=p->next; } } void Revise(LN *p) { LN *a; LN *b; int n; int i=0; int data; printf("Input which node you want to insert:"); scanf("%d",&n); printf("Please input the data:"); scanf("%d",&data); while (i<n-1) { p=p->next; i++; } a=(LN *)malloc(sizeof(LN)); b=(LN *)malloc(sizeof(LN)); p->num=data; a=p->next; p->next=b; b->next=a; } ``` 其中在链表插入当中插入错误,插入节点是对的,但是数就是错的。

C语言链表插入操作,一个函数

Description 已知线性表中元素为整数,且按照升序排列。编写算法实现在线性表中查找值为x的元素,如果查找成功,返回1;否则,返回0,并且把x插入到正确的位置,使线性表仍按升序排列。 依次输出调用查找插入算法后的线性表中的元素。 提示:存储结构采用代表头结点的循环单链表,结点结构如下: typedef struct Node { int data; struct Node *next; }LNode,*LinkList; 要求: (1)编写函数建立循环单链表CreateLinkList(int n),函数返回值类型为LinkList。 LinkList CreateLinkList(int n) { /*按照升序输入n个整数,建立带表头结点的循环单链表*/ } (2) 编写查找函数QueryLinkList(LinkList *L,int x)实现查找并插入功能,函数返回值类型int。 int QueryLinkList(LinkList *L,int x) { /*查找值为x的元素,若查找成功返回1,否则返回0,并把x插入到相应的位置。*/ } (3)编写函数Display(LinkList L),输出线性表中的元素。 (4)main函数调用QueryLinkList()函数,输出查找结果,然后调用Display函数依次输出线性表中的元素。 Input 输入元素个数n 依次输入n个升序排列的整数 输入带查找的元素值x Output 输出查找结果1或者0 依次输出线性表中的元素值 Sample Input sample 1: 6 2 5 8 10 12 16 10 sample2: 6 2 5 8 10 12 16 9 Sample Output sample 1: 1 2 5 8 10 12 16 sample2: 0 2 5 8 9 10 12 16

c语言链表插入节点出错,不知道插入函数错在哪一步

#include<stdio.h> #include<stdlib.h> #include<string.h> struct date { int year; int month; int day; }; struct student { int num; char name[10]; int score[2]; struct date birth; struct student *pnext; }; int icount; struct student *create() { struct student *phead=NULL; struct student *pnew,*pend; icount=0; printf("please input the information:\n"); pend=pnew=(struct student*)malloc(sizeof(struct student)); scanf("%d",&pnew->num); scanf("%s",pnew->name); scanf("%d,%d",&pnew->score[0],&pnew->score[1]); scanf("%d,%d,%d",&pnew->birth.year,&pnew->birth.month,&pnew->birth.day); while(pnew->num!=0) { icount++; if(icount==1) { pnew->pnext=phead; pend=pnew; phead=pnew; } else { pnew->pnext=NULL; pend->pnext=pnew; pend=pnew; } printf("please input the information:\n"); pend=pnew=(struct student*)malloc(sizeof(struct student)); scanf("%d",&pnew->num); scanf("%s",pnew->name); scanf("%d,%d",&pnew->score[0],&pnew->score[1]); scanf("%d,%d,%d",&pnew->birth.year,&pnew->birth.month,&pnew->birth.day); } free(pnew); return phead; } struct student *Insert(struct student *phead) { struct student *ptemp,*pnew; int i=1,n; ptemp=phead; printf("please enter the location you want to insert:\n"); scanf("%d",&n); while((n<0)||(n>icount)) { printf("input error,please reinput:\n"); scanf("%d",&n); } while(i<n) { ptemp=ptemp->pnext; i++; } printf("please input the information:\n"); pnew=(struct student*)malloc(sizeof(struct student)); scanf("%d",&pnew->num); scanf("%s",pnew->name); scanf("%d,%d",&pnew->score[0],&pnew->score[1]); scanf("%d,%d,%d",&pnew->birth.year,&pnew->birth.month,&pnew->birth.day); pnew->pnext=ptemp->pnext; ptemp->pnext=pnew; icount++; return phead; } void Print(struct student *phead) { struct student *ptemp; int j=1; ptemp=phead; printf("there are all %d students' information:\n",icount); while(ptemp!=NULL) { printf("this is the NO.%d students' information:\n",j); printf("number:%d\n",ptemp->num); printf("name:%s\n",ptemp->name); printf("Maths:%d,Chinese:%d\n",ptemp->score[0],ptemp->score[1]); printf("birthday--year:%d,month:%d,day:%d\n",ptemp->birth.year,ptemp->birth.month,ptemp->birth.day); ptemp=ptemp->pnext; j++; } } int main() { struct student *p; p=create(); p=Insert(p); Print(p); return 0; }

c语言链表节点删除问题求解

这是一个删除结点并输出的程序,总共有三个链表 错误为:当删除最后一个链表也就是3时程序发生错误,停止运行。 求大家帮忙解解决! ``` #include <stdio.h> #define NUll 0 #include <stdlib.h> struct stu { char name[6]; int xuehao; int grade; struct stu *next; }; typedef struct stu STU; main() { STU *p,*p_start,*p2,*p_print,*p_charu,*p_charu2; int i,xuehao; //输入 for (i=0;i<3;i++) { p=(STU *)malloc(sizeof(STU)); printf("请输入学生姓名:\n"); scanf("%s",&p->name); printf("请输入学生的学号:\n"); scanf("%d",&p->xuehao); printf("请输入学生的成绩:\n"); scanf("%d",&p->grade); if (i==0) p2=p_start=p; else { p2->next=p; p2=p; if (i==2) p->next=NULL; } } //链表的删除 p_charu=p_start; printf("请输入要删除的学号\n"); scanf("%d",&xuehao); while (1) { p_charu2=p_charu->next; if (p_charu->next->xuehao==xuehao) { p_charu->next=p_charu->next->next; free(p_charu2); break; } if (p_charu->xuehao==xuehao) { p_start=p_charu->next; free(p_charu); break; } p_charu=p->next; } } ```

C语言,如何新建链表节点

typedef struct CDLNode { char CDName[15]; char country[10]; char CDType[10]; int isLended; struct CDLNode * next; }CDLNode,*CDLinkList; 如何实现在main函数的循环中新建一个CDLNode节点,节点中的数据由用户输入啊(use c)?详细一点谢谢各位 !!

c语言链表删除问题,输入一个数字,查找所有此数字的节点全部删除,,,,,,,,,,,,,,,,,,

我想知道在有重复的情况下怎么写,,,,我之前写的都是删除单一节点,,,,,重复的情况不会写

C语言单链表的插入求解了

对于带有头结点的链表,为什么在插入方法需要传入头指针的地址(二重指针)?对于不带头结点的链表,插入或者删除第一个元素时,需要使用头指针的地址,可是对于带头结点链表,为何要呢?

C语言 单向链表的遍历问题!

你好,我这个单向链表的遍历函数为什么会一直循环 不停止。代码如下: ``` #include <stdio.h> #include <stdlib.h> #include <math.h> #include <string.h> struct Node; typedef struct Node *PNode;//指向下一个struct Node用的 typedef double DataType; struct Node{ DataType info; PNode link;//next指针 }; typedef struct Node *LinkList; //单链表类型 的指针 //用这个构建函数 返回变量为struct Node型的指针 LinkList createNullList_link(void){ /*构建空单链表*/ LinkList llist = (LinkList)malloc(sizeof(struct Node)); if(llist!=NULL) llist->link=NULL; else printf("构建空的单链表失败\n"); return llist; } void isNullList_link(LinkList llist){ /*判断是否为空链表*/ if(llist->link==NULL){ printf("是空链表\n"); } else{ printf("不是空链表\n"); } } ; PNode locate_link(LinkList llist, DataType x){ /*判断第一个元素x在单链表中存储的位置*/ PNode p; if(llist==NULL) { printf("这个是空链表\n"); return NULL; } ; p = llist->link; while(p!=NULL&&p->info!=x){ p = p->link; }; printf("找到元素x所存储的位置\n"); return p;//返回p,p指向的是那个节点 } int insertPost_Link(LinkList llist, PNode p, DataType x){ /*在p所指的节点(p已经是个节点了)后面插入新节点,经常与locate_link函数连用,意思实在p之后插入节点*/ PNode q = (PNode)malloc(sizeof(struct Node));//申请新的节点 if(q==NULL) { printf("新节点构建失败\n"); return 0; } else { q->info = x; q->link = p->link;//q的link指向了原来p的link应该指的节点 p->link = q;//原来的p->link 指向了q 节点 printf("新节点插入成功\n"); return 1; } } /*--------------------------------------------------*/ PNode locatePre_link(LinkList llist, PNode p){ /*求p所指的节点之前的节点,与函数locate_link连用*/ PNode p1; if(llist==NULL) { printf("这是空的链表\n"); return NULL; } p1 = llist; while(p1!=NULL && p1->link != p){ p1 = p1->link; } printf("找到了\n"); return p1; } void insertPre_Link(LinkList llist, PNode p, DataType x){ /*在p 所指的 节点 前面插入新节点,与locatePre_link连用*/ PNode q = (PNode)malloc(sizeof(struct Node));//申请新的节点 if(q==NULL) { printf("新节点构建失败\n"); } else { q->info = x; q->link = p->link;//q的link指向了原来p的link应该指的节点 p->link = q;//原来的p->link 指向了q 节点 printf("新节点插入成功\n"); } } /*-------------------------------------------------------------------*/ int deleteV_link(LinkList llist, DataType x){ /*删除第一个元素值为x的节点*/ PNode p, q; p = llist; if(p==NULL){ printf("这是个空链表\n"); return 0; } while(p->link!=NULL && p->link->info!=x){ /*p->link所指的节点的数据不等于x*/ p = p->link; } if(p->link == NULL){ printf("不存在这个存储元素的节点\n"); return 0; } else{ q = p->link ; p->link = q->link ; free(q); printf("删除成功\n"); return 1; } } int deleteP_link(LinkList llist, PNode p){ /*删除p所指的节点*/ if(llist==NULL){ printf("这是个空链表\n"); return 0; } PNode p1; p1 = locatePre_link(llist, p); p1->link = p->link ; free(p); printf("删除成功\n"); return 1; } void DisplayList(LinkList head){ //遍历带头结点的单链表 LinkList p = head; if(head == NULL){ printf("这是个空链表\n"); } int i = 0; for (i =0;;i++){ if(p->info==-1) break; printf("%lf ",p->info ); p = p->link; } printf("\b\n"); } /*--------------------------*/ int main() { LinkList head,q,tail; q = createNullList_link(); head = q; tail = q; isNullList_link(q); double info_1 = 0; printf("请输入第一个节点的元素:\n"); scanf("%lf", &info_1); q->info = info_1; head = q; q->link = tail; tail == NULL; isNullList_link(q); PNode t = q; int i; printf("请输入你要插入的元素,并以-1结束\n"); for(i = 0;; i ++ ){ double x = 0.0; scanf("%lf",&x); if(x==-1) break; int y = insertPost_Link(q,t,x); t = t->link; } DisplayList(head); printf("运行完毕,按任意键退出\n"); system("pause"); return 0; } ```

C语言链表数据输入问题

有链表指针p1,想向结构体中的结构体时间中的变量日输入数值,如何写代码?

关于C语言链表学习入门遇到瓶颈

怎样学习C语言中的链表,有没有什么好的文章博客,详细易懂,发一下链接,谢谢

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"); }

c语言链表头部插不进去信息

![图片说明](https://img-ask.csdn.net/upload/201702/21/1487658991_690580.png)![![图片说明](https://img-ask.csdn.net/upload/201702/21/1487659037_239052.png)图片说明](https://img-ask.csdn.net/upload/201702/21/1487659022_155222.png) 图片是链表的插入部分代码,头部认为是0位置 ,现在除了头部之外 其他地方都可以插入信息了 ,但是插入到头部 遍历出来的还是没有 这个是什么问题啊 check是遍历的函数

如何理解链表中指针和节点的意义

1.节点中有Data元素和Next元素,指针是直线这个节点还是指向该节点中的Data元素? 2.如何理解双向链表中【p节点前驱的后继】,是指p节点前驱指向的节点(如p-1节点)的后继指向的节点(p)吗?

C语言循环链表的头节点是定义成变量好,还是定义成结构体好?

C语言循环链表的头节点是定义成变量好,还是定义成结构体好?

c语言链表尾插法思路分析

![图片](https://img-ask.csdn.net/upload/201703/05/1488682196_932629.jpg)![图片](https://img-ask.csdn.net/upload/201703/05/1488682440_11686.jpg)![图片](https://img-ask.csdn.net/upload/201703/05/1488682216_1882.jpg)

c语言链表排序问题(非交换成员)

struct scool student{ char name[10]; int score; } 从键盘获取输入,创建这样一个链表。 然后按照成绩值进行降序排序(交换链表中结构体位置而不是成员值)怎么实现。我通过冒泡排序for(one=head;one!=NULL;one=one->next) for(two=one->next;two!=NULL;two=two->next) { if() {......} } 一直实现不了,不知道哪里出问题。

C语言中的链表赋值问题

我写了一个存储电影名字以及评级的链表,不理解其中以下三点 1.prev->next=current, 2.prev=current, 3.current=current->next 我目前的理解是:1.把current这个结构体指针变量的地址赋值给prev中的结构体指针变量next;2.把current这个结构体指针变量的地址赋值给结构体指针变量prev;3.令结构体指针变量current的值等于结构体指针变量next的值 不知道对吗? 以下是我的源代码: #include<stdio.h> #include<stdlib.h> //malloc();原型 #include<string.h> //strcpy();原型 #define SIZE 20 //最大字数 typedef struct film { char title[SIZE]; int rating; struct film * next; }Film; int main() { Film *head=NULL; Film *prev,*current; char title2[SIZE]; //写入 puts("Scan first title(0-20 charecter)"); while(gets(title2)!=EOF&&title2[0]!='\0') { current = (Film *)malloc(sizeof(Film)); //存第一个指针head if(head==NULL) { head=current; } //current's address 赋给next else prev->next=current; strcpy(current->title,title2); puts("Rating is...(0-10)"); scanf("%d",&current->rating); getchar(); //节点更换 puts("Enter next movie title"); prev=current; } //显示 if(head) { current=head; while(current!=NULL) { printf("the title is %s,the rating is %d\n",current->title,current->rating); current=current->next; //把下一个结构体指针的地址给current } } else puts("Not find any dota..."); //清内存 current=head; while(current) { free(current); current=current->next; } puts("OK!"); return 0; } 十分感谢

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

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

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

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

Java基础知识面试题(2020最新版)

文章目录Java概述何为编程什么是Javajdk1.5之后的三大版本JVM、JRE和JDK的关系什么是跨平台性?原理是什么Java语言有哪些特点什么是字节码?采用字节码的最大好处是什么什么是Java程序的主类?应用程序和小程序的主类有何不同?Java应用程序与小程序之间有那些差别?Java和C++的区别Oracle JDK 和 OpenJDK 的对比基础语法数据类型Java有哪些数据类型switc...

我以为我学懂了数据结构,直到看了这个导图才发现,我错了

数据结构与算法思维导图

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

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

和黑客斗争的 6 天!

互联网公司工作,很难避免不和黑客们打交道,我呆过的两家互联网公司,几乎每月每天每分钟都有黑客在公司网站上扫描。有的是寻找 Sql 注入的缺口,有的是寻找线上服务器可能存在的漏洞,大部分都...

Linux 会成为主流桌面操作系统吗?

整理 |屠敏出品 | CSDN(ID:CSDNnews)2020 年 1 月 14 日,微软正式停止了 Windows 7 系统的扩展支持,这意味着服役十年的 Windows 7,属于...

讲一个程序员如何副业月赚三万的真实故事

loonggg读完需要3分钟速读仅需 1 分钟大家好,我是你们的校长。我之前讲过,这年头,只要肯动脑,肯行动,程序员凭借自己的技术,赚钱的方式还是有很多种的。仅仅靠在公司出卖自己的劳动时...

学习总结之HTML5剑指前端(建议收藏,图文并茂)

前言学习《HTML5与CSS3权威指南》这本书很不错,学完之后我颇有感触,觉得web的世界开明了许多。这本书是需要有一定基础的web前端开发工程师。这本书主要学习HTML5和css3,看...

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

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

搜狗输入法也在挑战国人的智商!

故事总是一个接着一个到来...上周写完《鲁大师已经彻底沦为一款垃圾流氓软件!》这篇文章之后,鲁大师的市场工作人员就找到了我,希望把这篇文章删除掉。经过一番沟通我先把这篇文章从公号中删除了...

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

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

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

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

新一代神器STM32CubeMonitor介绍、下载、安装和使用教程

关注、星标公众号,不错过精彩内容作者:黄工公众号:strongerHuang最近ST官网悄悄新上线了一款比较强大的工具:STM32CubeMonitor V1.0.0。经过我研究和使用之...

记一次腾讯面试,我挂在了最熟悉不过的队列上……

腾讯后台面试,面试官问:如何自己实现队列?

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

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

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

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

冒泡排序动画(基于python pygame实现)

本项目效果初始截图如下 动画见本人b站投稿:https://www.bilibili.com/video/av95491382 本项目对应github地址:https://github.com/BigShuang python版本:3.6,pygame版本:1.9.3。(python版本一致应该就没什么问题) 样例gif如下 ======================= 大爽歌作,mad

Redis核心原理与应用实践

Redis核心原理与应用实践 在很多场景下都会使用Redis,但是到了深层次的时候就了解的不是那么深刻,以至于在面试的时候经常会遇到卡壳的现象,学习知识要做到系统和深入,不要把Redis想象的过于复杂,和Mysql一样,是个读取数据的软件。 有一个理解是Redis是key value缓存服务器,更多的优点在于对value的操作更加丰富。 安装 yum install redis #yum安装 b...

现代的 “Hello, World”,可不仅仅是几行代码而已

作者 |Charles R. Martin译者 | 弯月,责编 | 夕颜头图 |付费下载自视觉中国出品 | CSDN(ID:CSDNnews)新手...

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

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

!大部分程序员只会写3年代码

如果世界上都是这种不思进取的软件公司,那别说大部分程序员只会写 3 年代码,恐怕就没有程序员这种职业。

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

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

2020阿里全球数学大赛:3万名高手、4道题、2天2夜未交卷

阿里巴巴全球数学竞赛( Alibaba Global Mathematics Competition)由马云发起,由中国科学技术协会、阿里巴巴基金会、阿里巴巴达摩院共同举办。大赛不设报名门槛,全世界爱好数学的人都可参与,不论是否出身数学专业、是否投身数学研究。 2020年阿里巴巴达摩院邀请北京大学、剑桥大学、浙江大学等高校的顶尖数学教师组建了出题组。中科院院士、美国艺术与科学院院士、北京国际数学...

为什么你不想学习?只想玩?人是如何一步一步废掉的

不知道是不是只有我这样子,还是你们也有过类似的经历。 上学的时候总有很多光辉历史,学年名列前茅,或者单科目大佬,但是虽然慢慢地长大了,你开始懈怠了,开始废掉了。。。 什么?你说不知道具体的情况是怎么样的? 我来告诉你: 你常常潜意识里或者心理觉得,自己真正的生活或者奋斗还没有开始。总是幻想着自己还拥有大把时间,还有无限的可能,自己还能逆风翻盘,只不是自己还没开始罢了,自己以后肯定会变得特别厉害...

HTTP与HTTPS的区别

面试官问HTTP与HTTPS的区别,我这样回答让他竖起大拇指!

程序员毕业去大公司好还是小公司好?

虽然大公司并不是人人都能进,但我仍建议还未毕业的同学,尽力地通过校招向大公司挤,但凡挤进去,你这一生会容易很多。 大公司哪里好?没能进大公司怎么办?答案都在这里了,记得帮我点赞哦。 目录: 技术氛围 内部晋升与跳槽 啥也没学会,公司倒闭了? 不同的人脉圈,注定会有不同的结果 没能去大厂怎么办? 一、技术氛围 纵观整个程序员技术领域,哪个在行业有所名气的大牛,不是在大厂? 而且众所...

男生更看重女生的身材脸蛋,还是思想?

往往,我们看不进去大段大段的逻辑。深刻的哲理,往往短而精悍,一阵见血。问:产品经理挺漂亮的,有点心动,但不知道合不合得来。男生更看重女生的身材脸蛋,还是...

程序员为什么千万不要瞎努力?

本文作者用对比非常鲜明的两个开发团队的故事,讲解了敏捷开发之道 —— 如果你的团队缺乏统一标准的环境,那么即使勤劳努力,不仅会极其耗时而且成果甚微,使用...

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

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

立即提问
相关内容推荐