链表插入时while(p)和while(p->Next)有何不同

#include "stdio.h"
#include "stdlib.h"
typedef struct List
{
int data;
struct List *Next;
}Node,*NodePtr;
NodePtr ListPtr;

void ListInsert(NodePtr L,int i)
{
NodePtr p;
NodePtr q;
p = L;
while(p) //在这里我用 while(p)的话程序就会卡死在这里,如果用while(p->Next)就可以正常运行,请问是为什么
{

p = p->Next;

}
q = (Node*)malloc(sizeof(Node));
q->data = i;

p->Next = q;
printf("111\n");
p=q;
p->Next = NULL;

}
void ListCreatTail(NodePtr L)
{
*L = (Node
)malloc(sizeof(Node));
(*L)->Next = NULL;
}

void ListDelete(NodePtr L, int i)
{
int j = 1;
NodePtr p,q;
p=L;
while(p,j < i)
{
p=p->Next;
++j;
}
q=p->Next;
p->Next = q->Next;
free(q);

}

void ListPrintf(NodePtr L)
{
NodePtr p;
p=L->Next;
while(p)
{
printf("%d\n",p->data);
p=p->Next;
}
}

void main()
{

ListCreatTail(&ListPtr);
ListInsert(ListPtr,1);
ListInsert(ListPtr,2);
ListInsert(ListPtr,3);
ListInsert(ListPtr,4);
ListInsert(ListPtr,5);
ListDelete(ListPtr,2);
ListPrintf(ListPtr);
}

1个回答

while(p)指的是当p!=NULL时执行while循环里面的语句,所以退出循环的时候p=NULL, 而你下面有一句p->next=q ,p已经等于NULL, 再用p->next就会出错

jiaxue4818
宇陳 谢谢 明白了 您看一下我这个创建方式是不是带头结点呢
6 个月之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
对俩个链表进行合并用指针p1和p2可以,对L1,L2进行取值为什么不对?
链表中指针的问题 ,新定义指针对链表操作与直接对链表操作区别,代码如下? ``` 代码1 List Merge( List L1, List L2 ) { List L,q; L =malloc(sizeof(struct Node)); q =L; L1=L1->Next; L2=L2->Next; while(L1&&L2) { if(L1->Data<L2->Data) { q->Next=L1; q =L1; L1=L1->Next; } else { q->Next=L2; q =L2; L2=L2->Next; } } q->Next =L1?L1:L2; L1->Next=NULL; L2->Next=NULL; return L; } 代码2 List Merge( List L1, List L2 ) { List L; L=malloc(sizeof(struct Node)); List p;//用P做游标遍历链表 p=L; List p1=L1->Next;//头插法 List p2=L2->Next; while(p1&&p2) { if(p1->Data<p2->Data) { p->Next=p1; p=p1; p1=p1->Next; } else { p->Next=p2; p=p2; p2=p2->Next; } } p->Next=p1?p1:p2; L1->Next=NULL;//为了输出 L2->Next=NULL; return L; }//代码2用p1和p代替L1和L2,代码直接对L1,L2为什么不对 ```
关于两条升序的链表,合并成一条新的升序链表; if函数底下的tail已经指向了q,为什么while里面的函数让tail->next继续指向q
plist *merge(plist *ah,plist *bh) //合并函数 { plist *head,*tail,*p=ah,*q=bh,*ptemp; if(ah==NULL)return bh; if(bh==NULL)return ah; tail=p; if(p->no>q->no) tail=q; while(NULL!=p&&NULL!=q) { if(p->no<=q->no) { ptemp=p;p=p->next; } else { ptemp=q;q=q->next; } tail->next=ptemp;tail=ptemp; } if(NULL==p) { p=q; } ptemp=p; tail->next=ptemp; return head; }
为什么尾插法循环链表在插入时会出错?
调试时发现插入函数在调用时没有响应,百思不得其解。 ``` #include <stdio.h> #include <stdlib.h> #include <conio.h> #include <windows.h> //结构体定义 typedef struct node { int x; int y; struct node *next; }Node,*Snack; //所用函数 void initsnack(Snack s); void insert_node(Snack s,int x,int y);//问题所在函数 void show(Snack s); int main() { Snack s; initsnack(s); insert_node(s,12,17); insert_node(s,15,16); show(s); } void initsnack(Snack s) { //初始化蛇身并赋值 带尾指针循环链表 s=(Node*)malloc(sizeof(Node)); s->next=s; printf("OK1\n"); } void insert_node(Snack s,int x,int y) { //插入节点 Snack p=(Node *)malloc(sizeof(Node)); if(!p) printf("overflow"); p->x=x; p->y=y; s->next=p;//调试时显示程序到这儿就不往下进行了,为什么啊? p->next=s; s=p; free(p); printf("OK2\n"); } void show(Snack s) { //显示函数 Snack p=(Snack)malloc(sizeof(Node)); p=s->next; while(p->next!=s->next) { p=p->next; printf("x=%d,y=%d\n",p->x,p->y); } } ```
c++链表:把数据插入链表,再打印,中间有其他语句时,则打印出了一个很奇怪的数,这是为什么?
把数据插入链表,再打印,中间有其他语句时,则打印出了一个很奇怪的数,这是为什么? ``` Evenlist.cpp Evenlist::Evenlist() { head=new evNode; head->next=NULL; } Evenlist::~Evenlist() { evNode *p =head; while (p) { evNode *q = p; p = p->next; delete q; } } bool Evenlist::isEmpty() { if(head->next==NULL) return true; else return false; } void Evenlist::addNode(evNode ev)//有序插入 { evNode*p,*q; evNode*pev=&ev; q=head; p=head->next; if(head->next==NULL){ head->next=pev; cout<<"插在空链表的尾部:"<<endl; cout<<head->next->occurtime<<" "<<head->next->ntype; } else{ while(p!=NULL){ if(pev->occurtime<p->occurtime){ q->next=pev; pev->next=p; cout<<"插在中间"<<endl; break; } else{ q=p; p=p->next; } } q->next=pev; cout<<"插在尾部:"<<endl; } bool Evenlist::deleteNode(evNode*firstEv) { if(isEmpty()){ return false; } else { // firstEv=head->next; head->next=firstEv->next; delete firstEv; cout<<"成功删除"; return true; } } void Evenlist::displayNode() { int i=0; evNode *p ; p=head->next; if(isEmpty()) cout<<"该链表为空"<<endl; while(p!=NULL) { i++; cout<<"第"<<i<<"个事件"; cout << "(" <<p->occurtime<< ", "<<p->ntype<<") "; p = p->next; } cout << endl; } ``` int main() { evNode evltem; Evenlist evList; evltem.occurtime=0;evltem.ntype=-1;evltem.next=NULL;//初始化evltem evList.addNode(evltem); cout<<"打印链表"<<endl;//当有这个语句时输出很奇怪的数,没有时则能正确输出 evList.displayNode(); return 0; } ``` ``` ``` Evenlist.h typedef struct evnode{ int occurtime; int ntype;//事件类型 struct evnode*next; }evNode; class Evenlist { private: evNode *head; public: Evenlist(); virtual ~Evenlist(); bool isEmpty(); void addNode(evNode ev); bool deleteNode(evNode*firstEv); void displayNode(); }; ``` 这是打印错误的截图 1. ![图片说明](https://img-ask.csdn.net/upload/202003/18/1584501219_455766.png) 正确是会打印出(0,-1)
我用链表进行插入语删除操作后,发生了越界,我的代码哪里错了吗?
#include<stdio.h> #include<malloc.h> #include<stdlib.h> #include <iostream> #include<string.h> typedef struct Student{ char num[10]; //学号 char name[10]; //姓名 char gender[2]; //性别 int age; //年龄 }Student; //链表的定义 typedef struct LNode{ Student* data; //存放学生信息的数据域 struct LNode *next; //指向下一个学生信息的指针域 }LNode,*linklist; void input(int n, LNode **head){ if(n <= 0){ printf("输入错误\n"); return; } LNode *p = *head = (LNode*)malloc(sizeof(LNode)); int i; for(i = 0; i < n; i++){ p->next=(LNode*)malloc(sizeof(LNode)); p->next->data = (Student*) malloc (sizeof(Student)); p->next->next = NULL; scanf("%s %s %s %d",p->next->data->num, p->next->data->name, p->next->data->gender, &p->next->data->age); p = p->next; } return; } //输出学生信息 void output(LNode *p){ p=p->next; while(p!= NULL){ printf("%s %s %s %d\n",p->data->num, p->data->name, p->data->gender, p->data->age); p = p->next; } printf("\n"); } //插入信息 void add(LNode *head, int n){ if(n<1){ printf("输入过小\n"); return; } LNode *p = (LNode*)malloc(sizeof(LNode)); p->next = NULL; scanf("%s %s %s %d",p->data->num, p->data->name, p->data->gender, &p->data->age); int i = 1; while(head!=NULL){ if(i == n){ p->next = head->next; head->next = p; break; } head = head->next; i++; } if(head==NULL){ head->next = p; } } //链表的删除 int del(LNode *head, int n,int sum){ if(n<1){ printf("输入过小\n"); return -1; } if(n>sum){ printf("输入过大\n"); return -1; } linklist p; p = (LNode*)malloc(sizeof(LNode)); int i = 1; while(i<=n-1) { head=head->next; i++; } p=head->next; head->next=head->next->next; free(p); return 1; } int main(void){ LNode *head = NULL; printf("请输入学生人数:"); int sum; scanf("%d",&sum); printf("请依次输入学号,姓名,性别,年龄:\n"); input(sum,&head); output(head); printf("请输入插入位置:"); int a; scanf("%d",&a); add(head,a); sum++; output(head); printf("请输入删除位置:"); int b; scanf("%d",&b); int temp; temp=del(head,b,sum); if(temp==1){ sum--; } output(head); return 0; }
链表排序的程序 但是会丢失头结点 能否讲解一下
void sort(Linknode *&L) { Linknode *p,*q,*pre; p=L->next->next ; L->next->next = NULL; while(p!=NULL) { q=p->next ; pre=L; while(pre->next!=NULL && L->next->data<p->data) pre=pre->next ; p->next =pre->next ; pre->next =p; p=q; } }
当s1,s2链表不为空时,s3为空,交集为空时程序停止工作
# 两个有序链表序列的交集 (20分) 已知两个非降序链表序列S1与S2,设计函数构造出S1与S2的交集新链表S3。 输入格式: 输入分两行,分别在每行给出由若干个正整数构成的非降序序列,用−1表示序列的结尾(−1不属于这个序列)。数字用空格间隔。 输出格式: 在一行中输出两个输入序列的交集序列,数字间用空格分开,结尾不能有多余空格;若新链表为空,输出NULL。 ``` #include <stdio.h> #include <stdlib.h> typedef struct LNode { int Data; struct LNode *Next; }List; int main() { List *s1,*s2,*s3,*p1,*p2,*p3; int x1,x2; s1 = (List *)malloc(sizeof(List)); s2 = (List *)malloc(sizeof(List)); s3 = (List *)malloc(sizeof(List)); s1->Next = NULL; s2->Next = NULL; p1 = s1; scanf("%d",&x1); while(x1 != -1) { p1->Next = (List*)malloc(sizeof(List)); p1->Next->Data = x1; p1 = p1->Next; p1->Next = NULL; scanf("%d",&x1); } scanf("%d",&x2); p2 = s2; while(x2 != -1) { p2->Next = (List*)malloc(sizeof(List)); p2->Next->Data = x2; p2 = p2->Next; p2->Next = NULL; scanf("%d",&x2); } p1 = s1->Next; p2 = s2->Next; p3 = s3; s3->Next = NULL; while(p1!=NULL&&p2!=NULL) { if(p1->Data>p2->Data) { p2 = p2->Next; } if(p1->Data<p2->Data) { p1 = p1->Next; } if(p1->Data == p2->Data) { p3->Next = p1; p1 = p1->Next; p2 = p2->Next; p3 = p3->Next; } p3->Next = NULL; } p3 = s3->Next; if(p3 != NULL) { printf("%d",p3->Data); p3 = p3->Next; while(p3 != NULL) { printf(" %d",p3->Data); p3 = p3->Next; } } if(s3->Next == NULL)//当s1,s2链表不为空时,s3为空,运行c错误 { printf("NULL"); } return 0; } ``` 当s1,s2链表不为空时,s3为空,交集为空时程序停止工作
C语言 初学链表,对&*符号使用感到迷惑
void merge (LNode *C,int x) //删除链表中单个结点 {LNode *p,*q; p=c; /*查找部分开始*/ while(*p.next!= NULL){ if(p->next->data==x) break; p=p->next; /*查找部分结束*/ if(p->next==null) return 0; else{ /*删除部分的开始*/ q=p->next; p->next=p->next->next; free(q); /*删除部分的结束*/ return 1; } } } 在p->next=p->next->next;这个操作中,LNode *C链表中某个结点的指针指向的地址发生了变化,为什么形参中是“LNode *C”而不是“LNode *&C”。如果说只是方法体内的形参发生了改变,链表C本身没有发生改变,那最终链表怎么会有删除的效果。
比较学号大小建立双向链表
typedef struct xueshengzheng { char xuehao[20]; struct xueshengzheng *Next; struct xueshengzheng *Last; }*hData,Data; struct xueshengzheng *head; head=(hData)malloc(sizeof(struct xueshengzheng)); head->Next=NULL; while(1) { hData p2=NULL,p1; p1=&head; p2=(hData)malloc(sizeof(struct xueshengzheng)); //录入信息的结点 scanf("%s",p2->xuehao); if(strcmp(p2->xuehao,"00000000")==0) break; p2->Next=NULL; if(head->Next==NULL) //头节点的连接 { head->Next=p2; p2->Last=head; } else { while((p1->Next!=NULL)&&(strcmp(p2->xuehao,p1->Next->xuehao)>0)) //判定结点连接位置 { p1=p1->Next; } if((strcmp(p2->xuehao,p1->xuehao)<0)&&(p1->Next!=NULL))//如果链表出现比新结点小的学号则将新结点连接 { p2->Next=p1->Next; p1->Next->Last=p2; p1->Next=p2; p2->Last=p1; printf("u"); } if(p1->Next==NULL) //如果链表到达末尾,则直接连接结点 { p1->Next=p2; p2->Last=p1; } } } 各位大佬,可以看看我这个根据学号建立的双向链表有什么问题吗。。。改了一天了,还是没改出来,真的大脑有点乱,请各位大佬高抬贵手了~~~谢谢大佬们。
,程序的目的是实现单链表的并集,不知道为何最后总时出现如图显示的错误
//List__L.cpp #define TRUE 1 #define FALSE 0 #define OK 1 #define ERROR 0 #include<stdio.h> #include<stdlib.h> typedef char ElemType; typedef struct Node{ ElemType data; struct Node *next; } Node, *LinkList; void InitList(LinkList *L); int ListLength(LinkList L); Node *Locate(LinkList L, ElemType e); int GetData(LinkList L, int i, ElemType *e); int InsList(LinkList L, int i, ElemType e); int DelList(LinkList L, int i, ElemType *e); void InitList(LinkList *L) { // 创建带头结点的空链表L *L = (LinkList)malloc(sizeof(Node)); // 生成头结点 (*L)->next = NULL; } int ListLength(LinkList L) { // 统计带头结点的单链表L中数据元素的个数 Node* p; p=L->next; int j=0; while(p!=NULL){ p=p->next; j++; } return j; } Node *Locate(LinkList L, ElemType e) { // 在带头结点的单链表L中查找其值与e相等的结点 // 若找到,则返回该结点的存储位置,否则返回NULL Node *p; p = L->next; while ( p != NULL ) if ( p->data != e ) p = p->next; else break; return p; } Node *Get(LinkList L, int i) { // 在带头结点的单链表L中查找第i(1≤i≤n)个结点 // 若找到,则返回该结点的存储位置; 否则返回NULL Node *p; int j; if ( i<1 ) return NULL; p = L; j = 0; while ( (p->next!=NULL) && (j<i) ) { p = p->next; j++; } return (i==j) ? p : NULL; } int GetData(LinkList L, int i, ElemType *e) { // 当第i个元素存在时,其值赋给e并返回OK,否则返回ERROR // 说明:在编本函数体时,可以使用前面的Get函数 Node *p; p->data=Get(L,i)->data; if((p->data!=NULL)&&(i>0)&&(i<=ListLength(L))){ *e=p->data; return OK;} else return ERROR; } int InsList(LinkList L, int i, ElemType e) { // 在带头结点的单链表L的第i个元素之前插入元素e Node *pre, *s; int j; if ( i<1 ) return ERROR; pre = L; j = 0; while ( pre!=NULL && j<i-1 ) // 查找第i-1个结点 { pre = pre->next; j++; } if ( !pre ) return ERROR; // i太大 s = (Node *)malloc(sizeof(Node)); // 生成新结点 s->data = e; s->next = pre->next; // 插入L中 pre->next = s; return OK; } int DelList(LinkList L, int i, ElemType *e) { // 在带头结点的单链表L中删除第i个元素 Node *pre, *r; int j; if ( i<1 ) return ERROR; pre = L; j = 0; while ( pre->next!=NULL && j<i-1) // 寻找被删除结点i的前驱结点i-1使pre指向它 { pre = pre->next; j++; } if ( !(pre->next) ) return ERROR; // i太大 r = pre->next; pre->next = pre->next->next; // 删除结点r *e = r->data; free(r); // 释放被删除的结点所占的内存空间 return OK; } ``` #include <stdio.h> #include <stdlib.h> #include "List_L.cpp" int CreateFromTail(LinkList L); void PrintList(LinkList L); int Union(LinkList La, LinkList Lb); int main() { LinkList A, B; printf("\nInput elements of SET A ( END with $) :\n"); InitList(&A); CreateFromTail(A); printf("Input elements of SET B ( END with $) :\n"); InitList(&B); CreateFromTail(B); printf("\nSET A : "); PrintList(A); printf("SET B : "); PrintList(B); Union(A, B); printf("\nAfter A = A U B , SET A : "); PrintList(A); getchar(); getchar(); return 0; } int Union(LinkList La, LinkList Lb) { // 将所有在线性表Lb中但不在La中的数据元素插入到La中 int La_Len, Lb_Len, i; ElemType e; La_Len = ListLength(La); // 求线性表的长度 Lb_Len = ListLength(Lb); for ( i=1; i<=Lb_Len; i++ ) { GetData(Lb, i, &e); // 取Lb中第i个数据元素赋给e if ( !Locate(La, e) ) // La中不存在和e相同的数据元素 if ( !InsList(La, ++La_Len, e) ) // 插入 return ERROR; } return OK; } // Union int CreateFromTail(LinkList L) { // 根据依次输入的数据元素的值,创建带头结点的单链表L Node *r, *s; ElemType c; r = L; while ( (c=getchar())!='$' ) { s=(Node*)malloc(sizeof(Node)); if (!s) return ERROR; s->data=c; r->next=s; r=s; } r->next=NULL; getchar(); return OK; } void PrintList(LinkList L) { // 输出带头结点的单链表L中各数据元素的值 LinkList p=L->next; while(p != NULL) { printf("%c", p->data); p = p->next; } printf("\n"); } ```
请各位帮帮忙:指定一个数据,如果双向非循环链表中的有n个重复数据,往其中插入n个新的节点。打印节点数据后就死循环了?
//*******************双向非循环链表**********************// ``` #include"myhead.h" ```typedef struct dou_list_node { int data; struct dou_list_node *next; struct dou_list_node *prev; }dou_list,*dou_link; ```dou_link init_list() { dou_link head_ptr=malloc(sizeof(dou_list)); head_ptr->prev=NULL; head_ptr->next=NULL; return head_ptr; } ```dou_link creat_node(int data) { dou_link newnode_ptr=malloc(sizeof(dou_list)); newnode_ptr->data=data;//数据域 newnode_ptr->next=NULL;//指针域 newnode_ptr->prev=NULL;//指针域 return newnode_ptr; } ```int insert_tailnode(int data,dou_link head_ptr)//尾增 { dou_link newnode_ptr=creat_node(data); if(newnode_ptr==NULL) { puts("新节点传创建失败"); return -1; } dou_link p=head_ptr;//寻找尾节点 ``` while(p->next) { p=p->next; } //后增数据 newnode_ptr->prev=p; p->next=newnode_ptr; return 0;} ``` int PriDouList(dou_link head_ptr) { dou_link p=head_ptr->next; if(p==NULL) { puts("链表为空"); return -1; } puts("链表数据如下(顺序):"); while(1) { printf("%d\n",p->data); if(p->next==NULL) break; p=p->next; } puts("链表数据如下(逆序):"); while(p) { printf("%d\n",p->data); p=p->prev; if(p==head_ptr) break; } return 0; } ```int NumOfListNode(dou_link head_ptr)//计算链表的节点数量(不包括头节点) { dou_link p=head_ptr->next; if(p==NULL) { puts("链表为空"); return -1; } int count=1; while(p=p->next) { count++; } return count; } ```int NumOfSpecifiedData(int des_data,dou_link head_ptr)//计算链表中指定数据的数量(不包括头节点) { int count=0; dou_link p=head_ptr; if(p->next==NULL) { puts("链表为空"); return -1; } while(p=p->next) { if(p->data==des_data) { count++; } } return count; } ``` int insert2_midnode(int des_data,int newdata,dou_link head_ptr) { while(head_ptr->next==NULL) { puts("无法对指定位置插入数据,链表为空"); return -1; } int num_spe_data=NumOfSpecifiedData(des_data,head_ptr);//寻找目标数据在链表中的数量 if(num_spe_data==0) { puts("找不到指定数据"); return -1; } else { //创建对应数量的新节点 dou_link newnode_ptr[num_spe_data]; for(int i=0;i<num_spe_data;i++) { newnode_ptr[i]=creat_node(newdata); //printf("%p\n%d\n",newnode_ptr[i],newnode_ptr[i]->data); } //找到目标位置并插入数据 dou_link p=head_ptr->next; while(1) { int i=0; if(p->data==des_data&&p->next!=NULL) { newnode_ptr[i]->next=p->next; newnode_ptr[i]->prev=p; p->next=newnode_ptr[i]; newnode_ptr[i]->next->prev=newnode_ptr[i]; i++; p=p->next; } else if(p->data==des_data&&p->next==NULL) { newnode_ptr[i]->prev=p; p->next=newnode_ptr[i]; return 0; } p=p->next; if(p==NULL) return 0; } } } ```int main() { dou_link head_ptr=init_list();//初始化 for(int i=1;i<4;i++) { insert_tailnode(i,head_ptr); } insert_tailnode(2,head_ptr); PriDouList(head_ptr); int des_data,newdata; puts("输入目标节点数据和新节点数据"); scanf("%d%d",&des_data,&newdata); insert2_midnode(des_data,newdata,head_ptr); PriDouList(head_ptr); } 上面的代码希望指定一个数据,在链表中找到相同的数据节点,并往后插入一个数据,如果指定数据在链表中有多个,则插入相应数量的新节点。 情况:编译无报错,如果指定的数据在链表中只有一个,打印出的链表无误。如果有多个,打印出来的链表就死循环了。 弄了好久了,希望热心人帮忙解答,谢谢。
逆序数据建立链表--按输入数据的逆序建立一个链表
要求实现一个函数,按输入数据的逆序建立一个链表 函数createlist利用scanf从输入中获取一系列正整数,当读到−1时表示输入结束。按输入数据的逆序建立一个链表,并返回链表头指针。 题目给出的代码: ``` #include <stdio.h> #include <stdlib.h> struct ListNode { int data; struct ListNode *next; }; struct ListNode *createlist(); int main() { struct ListNode *p, *head = NULL; head = createlist(); for ( p = head; p != NULL; p = p->next ) printf("%d ", p->data); printf("\n"); return 0; } ``` 正确答案代码: ``` /* 你的代码将被嵌在这里 */ struct ListNode *createlist(){ int num; struct ListNode *p=NULL,*head=NULL; scanf("%d",&num); while (num!=-1) { p=(struct ListNode*)malloc(sizeof(struct ListNode));//注意这里!!! p->data=num; p->next=head; head=p; scanf("%d",&num); } return head; } ``` 输出结果: ``` 6 5 -1 5 6 Program ended with exit code: 0 ``` 错误代码(将上述标注的代码行换了个位置): ``` struct ListNode *createlist(){ int num; struct ListNode *p=NULL,*head=NULL; scanf("%d",&num); p=(struct ListNode*)malloc(sizeof(struct ListNode));//换到while循环外面!! while (num!=-1) { p->data=num; p->next=head; head=p; scanf("%d",&num); } return head; } ``` 输出结果: ``` 6 5 -1 5 5 5 5 5 5 5 5 5 5 5 …… ``` 为什么会这样呢?
Process returned -1073741819 (0xC0000005),运行不出结果,头疼。初学C。
#include <iostream> #include <malloc.h> using namespace std; typedef struct linkednode { int data[2]; struct linkednode *next; } snode,*ptr; int main() { ptr creat(); ptr add_n(ptr ha,ptr hb); ptr p=NULL,q=NULL; cout<<"请按照次数递增输入次数与系数"<<endl; p=creat( ); q=creat( ); cout<<"111"<<endl; while(p->next!=NULL) { cout<<p->data[0]<<" "<<p->data[1]<<"%%"; p=p->next; } while(q->next!=NULL) { cout<<q->data[0]<<" "<<q->data[1]<<"%%"; q=q->next; } p=add_n(p,q); while(p->next!=NULL) { cout<<p->data[0]<<" "<<p->data[1]<<"%%"; p=p->next; } free(p); free(q); return 0; } ptr creat( ) { ptr a=NULL,head=NULL,tail=NULL; int x,c,i; char flag='T'; tail=(ptr)malloc(sizeof(snode)); head=tail; for( i=0;; i++) { cout<<"请输入次数"<<endl; cin>>c; cout<<"请输入系数"<<endl; cin>>x; a=(ptr)malloc(sizeof(snode)); tail->next=a; tail->data[0]=c; tail->data[1]=x; tail=a; cout<<"请选择是否继续输入,T为继续,F为终止"<<endl; cin>>flag; if(flag=='F') break; } tail->next=NULL; free(tail); free(a); return head; } ptr add_n(ptr ha,ptr hb) { ptr p,q,last_p,pre_q; int val; p=ha->next; q=hb->next; last_p=ha; pre_q=hb; while(p!=ha && q!=hb) { if(p->data[0]>q->data[0]) { pre_q->next=q->next; last_p->next=q; q->next=p; last_p=last_p->next; q=pre_q->next; } else { if(p->data[0]<q->data[0]) //第二种情况 { last_p=p; p=p->next; } else //第三种,指数相同的合并 { val=p->data[1]+q->data[1]; if(val!=0)//插入一个,删除一个 { p->data[1]=val; pre_q->next=q->next; free(q); last_p=p; p=p->next; q=pre_q->next; } else//删除系数相加后为0的结点 { last_p->next=p->next; pre_q->next=q->next; free(p); free(q); p=last_p->next; q=pre_q->next; } } } if(q!=hb) //插入hb中剩余的链表 { last_p->next=q; while (q->next!=hb) q=q->next; q->next=p; } free(hb);//释放hb表头监督元 } return ha; }
这是我在百度上找的,但是总是运行不了,来求救大神们出手了。
#include<stdio.h> #include<stdio.h> struct node { int data; node* next; } node* create(int Array[]) { node *p,*pre,*head; head = new node; head->next=NULL; pre=head; for(int i=0;i<10;i++){ p=new node; p->data=Array[i]; p->next=NULL; pre->next=p; pre=p; } return head; } int search(node* head,int x) { int cout=0 node* p=head->next; while(p!=NULL){ if(p->data==x) count++; p=p->next; } return count; } void insert(node* head,int pos,int x) { node* p=head; for(int i=0;i<pos-1;i++){ p=p->next; } node* q=new node; q->data=x; q->next=p->next; p->next=q; } void del(node* head,int x) { node* pre =head; while(p!=NULL){ if(p->data==x){ pre->next=p->next; delete(p); p=pre->next; }else{ pre=p; p=p->next; } } } int main() { int Array[9]={9,8,7,6,5,4,3,2,1}; node* L=create(Array); node* q=L; L=L->next; printf("输出所建链表的元素:"); while(L!=NULL){ printf("%d",L->data); L=L->next; } printf("\n查找元素为5的个数:%d\n",search(q,5)); del(q,5); printf("删除元素为5的结点之后的链表;"); L=q->next; while(L!=NULL){ printf("%d",L->data); L=L->next; } insert(q,8,10); printf("\n在第8个位置插入元素为10的结点之后的链表;"); L=q->next; while(L!=NULL){ printf("%d",L->data); L=L->next; } return 0; }
数据结构单链表print打印没有数据输出,为什么?
#include<iostream> //单链表的创建,插入,删除,打印 为什么没有输出数据呢? #include<stdlib.h> using namespace std; typedef struct LNode { int num; float score; struct LNode *next; }LNode/**Linklist*/; void CreateList_L(LNode *L,int n) //创建单链表 { LNode *p; L=new LNode; L->next=NULL; for(int i=n;i>0;i--) { p=new LNode; cout<<"enter num score:"<<endl; cin>>p->num>>p->score; //p.num 不对 为什么 p->next=L->next; L->next=p; } } int LinkInsert_L(LNode *L,int i, int num,float sco) //在单链表L中第i个位置之前插入元素 { LNode *p; p=L; int j=0; while(p&&j<i-1) //寻找第i-1个结点 { p=p->next; ++j; } if(!p||j>i-1)return -1; LNode *s=new LNode; //生成新节点 s->num=num; s->score=sco; s->next=p->next; p->next=s; } int ListDelete_L(LNode *L,int i,int num,float sco) //在带头结点的单链表L中,删除第i个元素,并返回其值 { LNode *p=L; int j=0; while(p->next&&j<i-1) { p=p->next; ++j; } if(!(p->next)||j>i-1)return -1; LNode *q=new LNode; q=p->next; p->next=q->next; num=q->num; sco=q->score; free(q); } void print(LNode *L,int n) //输出打印单链表数据 { LNode *p=L->next; cout<<"Now,these "<<n<<" records are:"<<endl; while(p!=NULL) { cout<<p->num<<" "<<p->score<<endl; p=p->next; } } int main() { void CreateList_L(LNode *L,int n); void print(LNode *L,int n); const int m=3; LNode* l; CreateList_L(l,m); print(l,m); return 0; }
写了链表插入函数 主函数却没实现插入功能
#include<iostream> #include<stdlib.h> #include<cstdio> #define OK 1 #define ERROR 0 #define OVERFLOW -2 using namespace std; typedef int ElemType; typedef int Status; typedef struct LNode { ElemType data; //结点的数据域 struct LNode *next; //结点的指针域 }LNode,*Linklist; //Linklist为指向结构体LNode的指针类型 void CreateList_R(Linklist &L,int n) //正位序输入n个元素的值,建立带表头结点的单链表L { int i; LNode *p,*r; L=new LNode; //生成新结点作为头结点,用头指针L指向头结点 L->next=NULL; //先建立一个带头结点的空链表 r=L; //尾指针r指向头节点 for(i=0;i<n;++i) { p=new LNode; //生成新结点 cin>>p->data; //输入元素值赋给新结点*p的数据域 p->next=NULL; r->next=p; //将新结点*p插入尾结点*r之后 r=p; //r指向新的尾结点*p } } void ListOutput(Linklist L) //输出链表 { LNode *p; p=L->next; while (p != NULL) { cout<<p->data<<" "; p=p->next; } cout<<endl; } Status ListInsert(Linklist &L,int i,ElemType e) //在带头结点的单链表L中第i个位置插入值为e的新结点 { LNode *p,*r; int j; p=L; j=0; while(p && (j<i-1)) { p=p->next; ++j; //查找第i-1个结点,p指向该节点 } if(!p||j>i-1) return ERROR; //i>n+1或i<1 r=new LNode; //生成新结点*m r->data=e; //将结点*m的数据域置为e r->next=p->next; //将结点*m的指针域指向结点ai p->next=r; //将结点*p的指针域指向结点m return OK; } void nizhi(Linklist &L) { LNode *s,*q; q=L->next; L->next=NULL; ////将链表断开分成两个链表,第二个链表不带头结点,q是头指针 while(q!=NULL) { s=q; //摘下第二个链表的首结点,使s指向它 q=q->next; s->next=L->next; //将结点*s头插到链表L中 L->next=s; } } int main() { Linklist L; ElemType e; int n; int i; cout<<"输入数据个数:"<<endl; cin>>n; cout<<endl; cout<<"输入链表:"<<endl; CreateList_R(L,n); cout<<"插入前的链表:"<<endl; ListOutput(L); cout<<endl<<"插入数据:"; cin>>e; ListInsert(L,i,e); cout<<"插入后的线性表:"<<endl; ListOutput(L); cout<<"逆置:"<<endl; nizhi(L); ListOutput(L); } ``` ```
新手求助,一个关于链表中出现的错误。
#include<stdio.h> #include<malloc.h> #include<stdlib.h> #define LEN sizeof(struct student)//student结构的大小 struct student *creat();//创建链表 struct student *insert(struct student *head,struct studnet *stu_2);//第一个参数:需要被插入的链表 //第二个参数:待插入的结构的地址 int print(struct student *head);//打印链表 struct student { int num; float score; struct student *next; }; int n; int main() { struct student *stu,*p,stu_2; int n; stu=creat(); p=stu; print(p); printf("\nPlease input the num to insert:"); scanf("%d",&stu_2.num); printf("Please input the score:"); scanf("%f",&stu_2.score); print(insert(stu,&stu_2)); printf("\n\n"); system("pause"); } struct student *creat() { struct student *head; struct student *p1,*p2; p1=p2=(struct student *)malloc(LEN); printf("Please enter the num:"); scanf("%d",&p1->num); printf("Please enter the score:"); scanf("%f",&p1->score); head=NULL; n=0; while(p1->num) { n++; if(n==1) { head=p1; } else { p2->next=p1; } p2=p1; p1=(struct student *)malloc(LEN); printf("\nPlease enter the num:"); scanf("%d",&p1->num); printf("Please enter the score:"); scanf("%f",&p1->score); } p2->next=NULL; return head; } int print(struct student *head) { struct student *p; printf("\nThere are %d records!\n\n",n); p=head; do { printf("学号为%d的学生成绩为:%f\n",p->num,p->score); p=p->next; } while(p); } struct student *insert(struct student *head,struct studnet *stu_2) { struct student *p0,*p1,*p2; p1=head; p0=stu_2; if(NULL==head) { head=p0; p0->next=NULL; } else { while((p0->num>p1->num)&&(p1->next!=NULL)) { p2=p1; p1=p1->next; } if(p0->num<=p1->num) { if(head==p1)//p1是头结点 ,插入头部 { head=p0; } else //普通情况,插入中间 { p2->next=p0; } p0->next=p1; } else//p0的num最大,插入到末尾 { p1->next=p0; p0->next=NULL; } } n++;//链表数据由于插入了一位而加一 return head; } 这是显示出现的错误: [Error] cannot convert 'student* to 'studnet* for argument '2" to 'student* insert(student*, studnet*)' [Error] cannot convert 'studnet*' to 'student*' in assignment
数据结构单链表合并问题
代码可以正常运行,但是提交到系统中说有内存错误,错误原因显示如下: 错误原因可能是: 非法的内存引用, 具体原因可能是: 1.数组越界使用; 2.指针的错误使用, 一般是对非用户区的地址空间进行读或者写操作; 3.越权操作文件指针, 程序中却未捕捉该类错误; 4.栈溢出, 一般是因为过多的递归调用或者过大的临时变量导致;5.程序使用的内存超过了题目设定的上限。 代码如下 单链表合并 ``` #include <iostream> #include<stdio.h> //用于scanf,printf标准输入输出 #include<stdlib.h> //用于malloc,free内存申请与释放 using namespace std; typedef struct Node *LinkList; struct Node { int data; LinkList next; }; LinkList CreatFromTail() //构建单链表 { LinkList q,r,L; int i,n; L=(Node*)malloc(sizeof(Node)); r=L; scanf("%d",&n); for(i=0;i<n;i++) { q=(Node*)malloc(sizeof(Node)); scanf("%d",&q->data); r->next=q; r=q; } r->next=NULL; return L; } LinkList merge(LinkList a,LinkList b) //合并两个链表 { LinkList p=a->next; while(p->next) { p=p->next; } p->next=b->next; free(b); return a; } LinkList DeleteSame(LinkList L) //删除链表中的重复元素 { LinkList p=L->next,q,r; while(p!=NULL) { r=p->next; q=p; while(r!=NULL) { if(r->data==p->data) { q->next=r->next; r=r->next; } else { q=q->next; r=r->next; } } p=p->next; } return L; } LinkList sort(LinkList L) //排序 { LinkList p=L->next,q,r; if(p!=NULL) { r=p->next; p->next=NULL; p=r; while(p!=NULL) { r=p->next; q=L; while(q->next!=NULL&&q->next->data<p->data) q=q->next; p->next=q->next; q->next=p; p=r; } } return L; } void show(LinkList l) //输出链表 { LinkList p=l; while(p) { p=p->next; printf("%d",p->data); printf(" "); } } int main() { LinkList w,v,y,z,s; w=CreatFromTail(); v=CreatFromTail(); y=merge(w,v); s=DeleteSame(y); z=sort(s); show(z); return 0; } ```
关于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; } ``` 其中在链表插入当中插入错误,插入节点是对的,但是数就是错的。
在中国程序员是青春饭吗?
今年,我也32了 ,为了不给大家误导,咨询了猎头、圈内好友,以及年过35岁的几位老程序员……舍了老脸去揭人家伤疤……希望能给大家以帮助,记得帮我点赞哦。 目录: 你以为的人生 一次又一次的伤害 猎头界的真相 如何应对互联网行业的「中年危机」 一、你以为的人生 刚入行时,拿着傲人的工资,想着好好干,以为我们的人生是这样的: 等真到了那一天,你会发现,你的人生很可能是这样的: ...
我在支付宝花了1分钟,查到了女朋友的开房记录!
在大数据时代下,不管你做什么都会留下蛛丝马迹,只要学会把各种软件运用到极致,捉奸简直轻而易举。今天就来给大家分享一下,什么叫大数据抓出轨。据史料证明,马爸爸年轻时曾被...
程序员请照顾好自己,周末病魔差点一套带走我。
程序员在一个周末的时间,得了重病,差点当场去世,还好及时挽救回来了。
卸载 x 雷某度!GitHub 标星 1.5w+,从此我只用这款全能高速下载工具!
作者 | Rocky0429 来源 | Python空间 大家好,我是 Rocky0429,一个喜欢在网上收集各种资源的蒟蒻… 网上资源眼花缭乱,下载的方式也同样千奇百怪,比如 BT 下载,磁力链接,网盘资源等等等等,下个资源可真不容易,不一样的方式要用不同的下载软件,因此某比较有名的 x 雷和某度网盘成了我经常使用的工具。 作为一个没有钱的穷鬼,某度网盘几十 kb 的下载速度让我...
20道你必须要背会的微服务面试题,面试一定会被问到
写在前面: 在学习springcloud之前大家一定要先了解下,常见的面试题有那块,然后我们带着问题去学习这个微服务技术,那么就会更加理解springcloud技术。如果你已经学了springcloud,那么在准备面试的时候,一定要看看看这些面试题。 文章目录1、什么是微服务?2、微服务之间是如何通讯的?3、springcloud 与dubbo有哪些区别?4、请谈谈对SpringBoot 和S...
为什么猝死的都是程序员,基本上不见产品经理猝死呢?
相信大家时不时听到程序员猝死的消息,但是基本上听不到产品经理猝死的消息,这是为什么呢? 我们先百度搜一下:程序员猝死,出现将近700多万条搜索结果: 搜索一下:产品经理猝死,只有400万条的搜索结果,从搜索结果数量上来看,程序员猝死的搜索结果就比产品经理猝死的搜索结果高了一倍,而且从下图可以看到,首页里面的五条搜索结果,其实只有两条才是符合条件。 所以程序员猝死的概率真的比产品经理大,并不是错...
毕业5年,我问遍了身边的大佬,总结了他们的学习方法
我问了身边10个大佬,总结了他们的学习方法,原来成功都是有迹可循的。
推荐10个堪称神器的学习网站
每天都会收到很多读者的私信,问我:“二哥,有什么推荐的学习网站吗?最近很浮躁,手头的一些网站都看烦了,想看看二哥这里有什么新鲜货。” 今天一早做了个恶梦,梦到被老板辞退了。虽然说在我们公司,只有我辞退老板的份,没有老板辞退我这一说,但是还是被吓得 4 点多都起来了。(主要是因为我掌握着公司所有的核心源码,哈哈哈) 既然 4 点多起来,就得好好利用起来。于是我就挑选了 10 个堪称神器的学习网站,推...
这些软件太强了,Windows必装!尤其程序员!
Windows可谓是大多数人的生产力工具,集娱乐办公于一体,虽然在程序员这个群体中都说苹果是信仰,但是大部分不都是从Windows过来的,而且现在依然有很多的程序员用Windows。 所以,今天我就把我私藏的Windows必装的软件分享给大家,如果有一个你没有用过甚至没有听过,那你就赚了????,这可都是提升你幸福感的高效率生产力工具哦! 走起!???? NO、1 ScreenToGif 屏幕,摄像头和白板...
阿里面试,面试官没想到一个ArrayList,我都能跟他扯半小时
我是真的没想到,面试官会这样问我ArrayList。
曾经优秀的人,怎么就突然不优秀了。
职场上有很多辛酸事,很多合伙人出局的故事,很多技术骨干被裁员的故事。说来模板都类似,曾经是名校毕业,曾经是优秀员工,曾经被领导表扬,曾经业绩突出,然而突然有一天,因为种种原因,被裁员了,...
大学四年因为知道了这32个网站,我成了别人眼中的大神!
依稀记得,毕业那天,我们导员发给我毕业证的时候对我说“你可是咱们系的风云人物啊”,哎呀,别提当时多开心啦????,嗯,我们导员是所有导员中最帅的一个,真的???? 不过,导员说的是实话,很多人都叫我大神的,为啥,因为我知道这32个网站啊,你说强不强????,这次是绝对的干货,看好啦,走起来! PS:每个网站都是学计算机混互联网必须知道的,真的牛杯,我就不过多介绍了,大家自行探索,觉得没用的,尽管留言吐槽吧???? 社...
良心推荐,我珍藏的一些Chrome插件
上次搬家的时候,发了一个朋友圈,附带的照片中不小心暴露了自己的 Chrome 浏览器插件之多,于是就有小伙伴评论说分享一下我觉得还不错的浏览器插件。 我下面就把我日常工作和学习中经常用到的一些 Chrome 浏览器插件分享给大家,随便一个都能提高你的“生活品质”和工作效率。 Markdown Here Markdown Here 可以让你更愉快的写邮件,由于支持 Markdown 直接转电子邮...
看完这篇HTTP,跟面试官扯皮就没问题了
我是一名程序员,我的主要编程语言是 Java,我更是一名 Web 开发人员,所以我必须要了解 HTTP,所以本篇文章就来带你从 HTTP 入门到进阶,看完让你有一种恍然大悟、醍醐灌顶的感觉。 最初在有网络之前,我们的电脑都是单机的,单机系统是孤立的,我还记得 05 年前那会儿家里有个电脑,想打电脑游戏还得两个人在一个电脑上玩儿,及其不方便。我就想为什么家里人不让上网,我的同学 xxx 家里有网,每...
2020 年,大火的 Python 和 JavaScript 是否会被取而代之?
Python 和 JavaScript 是目前最火的两大编程语言,但是2020 年,什么编程语言将会取而代之呢? 作者 |Richard Kenneth Eng 译者 |明明如月,责编 | 郭芮 出品 | CSDN(ID:CSDNnews) 以下为译文: Python 和 JavaScript 是目前最火的两大编程语言。然而,他们不可能永远屹立不倒。最终,必将像其他编程语言一...
史上最全的IDEA快捷键总结
现在Idea成了主流开发工具,这篇博客对其使用的快捷键做了总结,希望对大家的开发工作有所帮助。
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
这种新手都不会范的错,居然被一个工作好几年的小伙子写出来,差点被当场开除了。
谁是华为扫地僧?
是的,华为也有扫地僧!2020年2月11-12日,“养在深闺人不知”的华为2012实验室扫地僧们,将在华为开发者大会2020(Cloud)上,和大家见面。到时,你可以和扫地僧们,吃一个洋...
AI 没让人类失业,搞 AI 的人先失业了
最近和几个 AI 领域的大佬闲聊 根据他们讲的消息和段子 改编出下面这个故事 如有雷同 都是巧合 1. 老王创业失败,被限制高消费 “这里写我跑路的消息实在太夸张了。” 王葱葱哼笑一下,把消息分享给群里。 阿杰也看了消息,笑了笑。在座几位也都笑了。 王葱葱是个有名的人物,21岁那年以全额奖学金进入 KMU 攻读人工智能博士,累计发表论文 40 余篇,个人技术博客更是成为深度学习领域内风向标。 ...
2020年,冯唐49岁:我给20、30岁IT职场年轻人的建议
点击“技术领导力”关注∆每天早上8:30推送 作者|Mr.K 编辑| Emma 来源|技术领导力(ID:jishulingdaoli) 前天的推文《冯唐:职场人35岁以后,方法论比经验重要》,收到了不少读者的反馈,觉得挺受启发。其实,冯唐写了不少关于职场方面的文章,都挺不错的。可惜大家只记住了“春风十里不如你”、“如何避免成为油腻腻的中年人”等不那么正经的文章。 本文整理了冯...
最全最强!世界大学计算机专业排名总结!
我正在参与CSDN200进20,希望得到您的支持,扫码续投票5次。感谢您! (为表示感谢,您投票后私信我,我把我总结的人工智能手推笔记和思维导图发送给您,感谢!) 目录 泰晤士高等教育世界大学排名 QS 世界大学排名 US News 世界大学排名 世界大学学术排名(Academic Ranking of World Universities) 泰晤士高等教育世界大学排名 中国共...
作为一名大学生,如何在B站上快乐的学习?
B站是个宝,谁用谁知道???? 作为一名大学生,你必须掌握的一项能力就是自学能力,很多看起来很牛X的人,你可以了解下,人家私底下一定是花大量的时间自学的,你可能会说,我也想学习啊,可是嘞,该学习啥嘞,不怕告诉你,互联网时代,最不缺的就是学习资源,最宝贵的是啥? 你可能会说是时间,不,不是时间,而是你的注意力,懂了吧! 那么,你说学习资源多,我咋不知道,那今天我就告诉你一个你必须知道的学习的地方,人称...
那些年,我们信了课本里的那些鬼话
教材永远都是有错误的,从小学到大学,我们不断的学习了很多错误知识。 斑羚飞渡 在我们学习的很多小学课文里,有很多是错误文章,或者说是假课文。像《斑羚飞渡》: 随着镰刀头羊的那声吼叫,整个斑羚群迅速分成两拨,老年斑羚为一拨,年轻斑羚为一拨。 就在这时,我看见,从那拨老斑羚里走出一只公斑羚来。公斑羚朝那拨年轻斑羚示意性地咩了一声,一只半大的斑羚应声走了出来。一老一少走到伤心崖,后退了几步,突...
使用 Python 和百度语音识别生成视频字幕
文章目录从视频中提取音频根据静音对音频分段使用百度语音识别获取 Access Token使用 Raw 数据进行合成生成字幕总结 从视频中提取音频 安装 moviepy pip install moviepy 相关代码: audio_file = work_path + '\\out.wav' video = VideoFileClip(video_file) video.audio.write_...
一个程序在计算机中是如何运行的?超级干货!!!
强烈声明:本文很干,请自备茶水!???? 开门见山,咱不说废话! 你有没有想过,你写的程序,是如何在计算机中运行的吗?比如我们搞Java的,肯定写过这段代码 public class HelloWorld { public static void main(String[] args) { System.out.println("Hello World!"); } ...
【蘑菇街技术部年会】程序员与女神共舞,鼻血再次没止住。(文末内推)
蘑菇街技术部的年会,别开生面,一样全是美女。
那个在阿里养猪的工程师,5年了……
简介: 在阿里,走过1825天,没有趴下,依旧斗志满满,被称为“五年陈”。他们会被授予一枚戒指,过程就叫做“授戒仪式”。今天,咱们听听阿里的那些“五年陈”们的故事。 下一个五年,猪圈见! 我就是那个在养猪场里敲代码的工程师,一年多前我和20位工程师去了四川的猪场,出发前总架构师慷慨激昂的说:同学们,中国的养猪产业将因为我们而改变。但到了猪场,发现根本不是那么回事:要个WIFI,没有;...
为什么程序猿都不愿意去外包?
分享外包的组织架构,盈利模式,亲身经历,以及根据一些外包朋友的反馈,写了这篇文章 ,希望对正在找工作的老铁有所帮助
Java校招入职华为,半年后我跑路了
何来 我,一个双非本科弟弟,有幸在 19 届的秋招中得到前东家华为(以下简称 hw)的赏识,当时秋招签订就业协议,说是入了某 java bg,之后一系列组织架构调整原因等等让人无法理解的神操作,最终毕业前夕,被通知调往其他 bg 做嵌入式开发(纯 C 语言)。 由于已至于校招末尾,之前拿到的其他 offer 又无法再收回,一时感到无力回天,只得默默接受。 毕业后,直接入职开始了嵌入式苦旅,由于从未...
世界上有哪些代码量很少,但很牛逼很经典的算法或项目案例?
点击上方蓝字设为星标下面开始今天的学习~今天分享四个代码量很少,但很牛逼很经典的算法或项目案例。1、no code 项目地址:https://github.com/kelseyhight...
立即提问