C语言中,feof读取到文件末尾时,返回的是数值,还是EOF?

stdio.h定义的好像就是#define EOF -1,那返回的到底是什么?课本说返回的是非零,但考试题上没这个选项啊。。。求解

c

2个回答

stdio.h中定义#define EOF -1,EOF在C++中的定义为:const int EOF = -1;EOF其实是整数-1,用于从文件读取数据的时候表示已经超越文件末尾这种错误状态。如果IO操作的结果是EOF,一般就意味着这次IO是失败的。
所以,当读取到文件末尾时,就返回EOF也就是-1

feof 返回的是数值
feof是C语言标准库函数,其原型在stdio.h中,其功能是检测流上的文件结束符,如果文件结束,则返回非0值,否则返回0
http://blog.csdn.net/a1066570234/article/details/78653862

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
做了个简单c语言通讯录出现了问题
就是选择分类的时候本来0是返回上一项菜单的,结果变成新的一类 #include<stdio.h> /*标准输入输出函数库*/ #include<stdlib.h> /*标准函数库*/ #include<string.h> #include<conio.h> FILE *fp; struct Data { int fenlei; char name[10]; //姓名 char tel[15]; //电话 char age[8]; //年龄 char qq[10]; //QQ号 } ren[1000]; struct Data1 { struct Data data; struct Data1 *next; } *p,*p1,*p2; struct zhanghao { char username[20]; char password[10]; } zh,*zh1,*zh2; struct LNode { char clas[20]; int length; struct Data1 *next; } a[6]; int menu() //主菜单选择函数 { int c; //定义一个整型变量 do { system("cls"); //清屏 printf("\t*******通讯录*******\n"); printf("\t--------------------\n"); printf("\t 1、通讯信息显示 \n"); printf("\t 2、通讯信息保存 \n"); printf("\t 3、通讯信息删除 \n"); printf("\t 4、通讯信息修改 \n"); printf("\t 5、通讯信息增加 \n"); printf("\t 6、通讯信息查询 \n"); printf("\t 0. 退出 \n"); printf("\t--------------------\n"); printf("\t请您选择(0-6):"); scanf("%d",&c); } while(c>7&&c<0); return(c); } void openclass() { FILE *fp1; int i; if ((fp1=fopen("contact.dat","r"))==NULL) { printf("\n不存在分类类别"); if ((fp1=fopen("contact.dat","w"))==NULL) //不存在则进行创建 { printf("\n建立失败"); exit(0); } strcpy(a[1].clas,"1.家人亲戚"); //依次将下一条信息复制到上一条的位置 strcpy(a[2].clas,"2.朋友"); strcpy(a[3].clas,"3.同学"); strcpy(a[4].clas,"4.同事"); strcpy(a[5].clas,"5.陌生人"); strcpy(a[6].clas,"6.其他"); for (i=1; i<=6; i++) { if (fprintf(fp1,"%s\n",a[i].clas)==0) { printf("\n文件保存错误!\n"); } a[i].length=0; a[i].next=NULL; } } else { rewind(fp1); for (i=1; !feof(fp1) && fscanf(fp1,"%s\n",a[i].clas); i++)a[i].next=NULL; printf("\n类别文件导入成功\n"); } fclose(fp1); //printf("\n按任意键返回主菜单:"); // getch();//按任意键退出 return; } int select() { int c,i=1; do { printf("\n1.家人亲戚\n"); printf("2.朋友\n"); printf("3.同学\n"); printf("4.同事\n"); printf("5.陌生人\n"); printf("6.其他\n"); printf("0.返回主菜单\n"); printf("请您选择(0-6):"); scanf("%d",&c); if(c<0||c>6) printf("输入错误!请重新输入:\n"); } while(c<0||c>6); if (c==0)return; else return (c); } int checkUerValid(struct zhanghao *zh1)/*校验用户合法性*/ { FILE*fp; struct zhanghao zh[1],*zh2=zh; char *usr,*pwd; int check=0; usr=zh1->username; pwd=zh1->password; if((fp=fopen("user.dat","rb"))==NULL) { printf("File open error!\n"); exit(0); } rewind(fp); fread(zh2,sizeof(struct zhanghao),1,fp); if((strcmp(usr,zh2->username)==0)&&(strcmp(pwd,zh2->password)==0)) { check=1; } if(fclose(fp)) { printf("不能关闭文件!\n"); exit(0); } return check; } void Readfile() { int n,i; openclass(); if((fp=fopen("user.dat","rb"))!=NULL) { printf("通讯录文件已存在。\n"); rewind(fp); fread(&p2,sizeof(struct zhanghao),1,fp); printf("请输入用户名:"); scanf("%s",zh.username); printf("请输入密码:"); scanf("%s",zh.password); while(checkUerValid(&zh)!=1) { printf("密码错误,请重新输入:\n"); printf("请输入用户名:"); scanf("%s",zh.username); printf("请输入密码:"); scanf("%s",zh.password); } fclose(fp); } if((fp=fopen("catalog.dat","rb"))==NULL) { printf("\n通讯录文件不存在!"); if ((fp=fopen("catalog.dat","wb"))==NULL) //不存在则进行创建 { printf("\n建立失败"); exit(0); } else { if ((fp=fopen("user.dat","wb"))==NULL) //不存在则进行创建 { printf("\n建立失败"); exit(0); } else { printf("\n输入注册号(不大于8位数):"); struct zhanghao zh[1],*zh1=zh; scanf("%s",zh1->username); while(strlen(zh1->username)>=8) { printf("\n注册号输入错误!请重新输入:"); scanf("%s",zh1->username); } printf("\n输入注册号密码(不大于8位数):"); scanf("%s",zh1->password); while(strlen(zh1->password)>=8) { printf("\n注册号输入错误!请重新输入:"); scanf("%s",zh1->password); } fwrite(zh1,sizeof(struct zhanghao),1,fp); } fclose(fp); printf("\n通讯录文件已建立\n"); printf("\n按任意键进入主菜单"); getch(); return; } exit(0); //退出 } fseek(fp,0,2); //文件位置指针移动到文件末尾 if (ftell(fp)>0) //文件不为空,获取的是文件长度 { //rewind(fp); //文件位置指针移动到文件开始位置 fseek(fp,0,0); //文件位置指针移动到文件开始位置 for ( n=0; !feof(fp) && fread(&ren[n],sizeof(struct Data),1,fp); n++); //for(i=0;i<=n;i++)printf("%s",dat[i].name); for(i=0; i<=n; i++) { p1=a[ren[i].fenlei].next; p=(struct Data1*)malloc(sizeof(struct Data1)); p->data=ren[i]; p->next=NULL; if(a[ren[i].fenlei].next==NULL) { a[ren[i].fenlei].next=p; a[ren[i].fenlei].length++; } else { while(p1->next!=NULL)p1=p1->next; p1->next=p; a[ren[i].fenlei].length++; } } //从文件流中读取数据,以Data结构体接收读取的数据,并由n记录下文件中联系人个数 printf("\n文件导入成功\n"); printf("\n按任意键进入主菜单:"); getch(); return; } fclose(fp); printf("\n文件导入成功\n"); printf("\n文件中没有数据\n"); printf("\n按任意键进入主菜单:"); getch();//按任意键退出 return; } int input1(struct LNode a[],int n) { char s[10]; char ch,m; while(ch!='n'&&ch!='N') { p1=a[n].next; printf("添加新联系人\n"); printf("姓名:"); p=(struct Data1*)malloc(sizeof(struct Data1)); p->next=NULL; scanf("%s",s); if(p1!=NULL) { while((strcmp(p1->data.name,s)!=0)&&p1->next!=NULL) p1=p1->next; if(strcmp(p1->data.name,s) == 0) { printf("通讯录中已有此人!\n"); printf("是否继续添加?(Y/N)"); scanf("%s",&m); while(m!='n'&&m!='N'&&m!='y'&&m!='Y') { printf("\n输入错误!请重新输入:"); scanf("%s",&m); } if(m!='n'&&m!='N') { input1(a,n); } return 0; } if(p1->next==NULL) { printf("电话:"); scanf("%s",p->data.tel); printf("电子邮件:"); scanf("%s",p->data.age); printf("QQ号:"); scanf("%s",p->data.qq); strcpy(p->data.name,s); printf("类别:%d",n); p->data.fenlei=n; p1->next=p; a[n].length++; } } else { printf("电话:"); scanf("%s",p->data.tel); printf("电子邮件:"); scanf("%s",p->data.age); printf("QQ号:"); scanf("%s",p->data.qq); strcpy(p->data.name,s); printf("类别:%d",n); p->data.fenlei=n; a[n].next=p; a[n].length++; } printf("\n是否继续添加?(Y/N)"); scanf("%s",&ch); while(ch!='n'&&ch!='N'&&ch!='y'&&ch!='Y') { printf("\n输入错误!请重新输入:"); scanf("%s",&ch); } } printf("\n添加成功!\n"); printf("\n按任意键返回主菜单:"); getch(); return 0; } void print11(struct LNode a[],int n) { int l=1; if(a[n].length>0) { printf("共%d条记录\n",a[n].length); p1=p=a[n].next; while(p!=NULL) { printf("\n%d\n类别:",l++); printf("%d\n",p->data.fenlei); printf("姓名:"); printf("%s\n",p->data.name); printf("电话:"); printf("%s\n",p->data.tel); printf("电子邮件:"); printf("%s\n",p->data.age); printf("QQ:"); printf("%s\n",p->data.qq); p=p->next; } } else printf("\n名片数为0!\n"); printf("\n按任意键返回主菜单:"); getch(); return; } void allprint(struct LNode a[]) { int n,sum=0,l=0; for(n=1; n<7; n++) { sum=sum+a[n].length; } printf("\n一共%d记录",sum); for(n=1; n<7; n++) { if(a[n].length>0) { printf("\n类别%d共%d条记录\n",n,a[n].length); p1=p=a[n].next; while(p!=NULL) { printf("%d\n",p->data.fenlei); printf("姓名:"); printf("%s\n",p->data.name); printf("电话:"); printf("%s\n",p->data.tel); printf("电子邮件:"); printf("%s\n",p->data.age); printf("QQ:"); printf("%s\n",p->data.qq); p=p->next; } } else printf("\n名片数为0!\n"); printf("\n按任意键返回主菜单:"); getch(); return; } } void print111(struct LNode a[]) { int m,n; printf("\n请选择显示方式:\n"); printf("1--分类显示 \n"); printf("2--全部显示\n"); printf("0--返回菜单\n"); printf("请选择(0-2):"); scanf("%d",&m); while(m!=1&&m!=2&&m!=0) { printf("\n输入错误,请重新选择:"); scanf("%d",&m); } if(m==1) { printf("\n请输入要查询的分类"); n=select(); print11(a,n); } if(m==2) { allprint(a); } if(m==0) { return; } } void namefind(struct LNode a[],int n) { char s[20]; int i=0; char m; printf("\n请输入想查询的姓名:"); scanf("%s",s); p1=p=a[n].next; if(p1==NULL) { printf("\n通讯录中没有此人!\n"); return; } while(p->next!=NULL) { while(strstr(p->data.name,s)==NULL&&p->next!=NULL)p=p->next; if(strstr(p->data.name,s)!=NULL) { i++; printf("\n类别:"); printf("%d\n",p->data.fenlei); printf("姓名:"); printf("%s\n",p->data.name); printf("电话:"); printf("%s\n",p->data.tel); printf("电子邮件:"); printf("%s\n",p->data.age); printf("QQ:"); printf("%s\n",p->data.qq); } if((p->next==NULL)&&i==0) { printf("\n通讯录中没有此人!\n"); printf("\n是否继续查询?(Y/N)"); scanf("%s",&m); while(m!='n'&&m!='N'&&m!='y'&&m!='Y') { printf("\n输入错误!请重新输入:"); scanf("%c",&m); } if(m!='n'&&m!='N') { namefind(a,n); } return; } if(p->next==NULL) { printf("\n查询完成!\n"); printf("\n是否继续查询?(Y/N)"); scanf("%s",&m); while(m!='n'&&m!='N'&&m!='y'&&m!='Y') { printf("\n输入错误!请重新输入:"); scanf("%s",&m); } if(m!='n'&&m!='N') { namefind(a,n); } return; } else p=p->next; } if(strstr(p->data.name,s)!=NULL) { i++; printf("\n类别:"); printf("%d\n",p->data.fenlei); printf("姓名:"); printf("%s\n",p->data.name); printf("电话:"); printf("%s\n",p->data.tel); printf("电子邮件:"); printf("%s\n",p->data.age); printf("QQ:"); printf("%s\n",p->data.qq); } printf("\n查询完成!\n"); printf("\n是否继续查询?(Y/N)"); scanf("%s",&m); while(m!='n'&&m!='N'&&m!='y'&&m!='Y') { printf("\n输入错误!请重新输入:"); scanf("%s",&m); } if(m!='n'&&m!='N') { namefind(a,n); } return; } void onedelete1(struct LNode a[],int n) { char s[20],r; int i=0; printf("请输入想删除联系人的姓名:"); scanf("%s",s); p1=p=a[n].next; if(p1==NULL) { printf("\n通讯录中没有此人!\n"); return; } while(strcmp(p->data.name,s)!=0&&p->next!=NULL)p=p->next; if(strcmp(p->data.name,s) != 0) { printf("\n通讯录中没有此人!\n"); return; } if(strcmp(p->data.name,s) == 0) { printf("类别:"); printf("%d\n",p->data.fenlei); printf("姓名:"); printf("%s\n",p->data.name); printf("电话:"); printf("%s\n",p->data.tel); printf("电子邮件:"); printf("%s\n",p->data.age); printf("QQ:"); printf("%s\n",p->data.qq); } printf("确认删除?(Y/N):"); scanf("%s",&r); while(r!='n'&&r!='N'&&r!='y'&&r!='Y') { printf("\n输入错误!请重新输入:"); scanf("%s",&r); } if(r=='y'||r=='Y') { if(p1==p)a[n].next=p->next; else { while(p1->next!=p)p1=p1->next; p1->next=p->next; } free(p); a[n].length--; printf("\n已经成功删除!\n"); return; } } //全部删除函数 void alldelete1(struct LNode a[],int n) { char r; p1=p=a[n].next; printf("\n确认删除?(Y/N):"); scanf("%s",&r); while(r!='n'&&r!='N'&&r!='y'&&r!='Y') { printf("\n输入错误!请重新输入:"); scanf("%s",&r); } if(r=='y'||r=='Y') { if(p1==NULL) { printf("不存在名片!"); return; } while(p1->next!=NULL) { p=p1->next; p1->next=p->next; free(p); } a[n].next=NULL; a[n].length=0; printf("\n已经成功删除全类名片!\n"); return; } if(r=='n'||r=='N') { return; } } //选择删除联系人函数 void delete11(struct LNode a[],int n) { int m; printf("\n请选择删除方式:\n"); printf("1--单个删除 \n"); printf("2--全部删除\n"); printf("0--返回菜单\n"); printf("请选择(0-2):"); scanf("%d",&m); while(m!=1&&m!=2&&m!=0) { printf("\n输入错误,请重新选择:"); scanf("%d",&m); } if(m==1) { onedelete1(a,n); } if(m==2) { alldelete1(a,n); } if(m==0) { return; } } void Save() { FILE *fp; int i; if ((fp=fopen("catalog.dat","wb"))==NULL) { printf("\n文件打开失败"); } for (i=1; i<=6; i++) { p=a[i].next; while(p!=NULL) { if (fwrite(&(p->data),sizeof(struct Data),1,fp)==0) { printf("\n文件保存错误!\n"); } p=p->next; } } fclose(fp); printf("\n按任意键返回主菜单:"); getch();//按任意键退出 return; } void namechange(struct LNode a[],int n) { char s[20]; char m,ch; int i=0,k; p1=a[n].next; printf("\n请输入想修改的联系人的姓名:"); scanf("%s",s); if(p1==NULL) { printf("\n通讯录中没有此人!\n"); printf("\n是否继续修改?(Y/N)"); scanf("%s",&ch); while(ch!='n'&&ch!='N'&&ch!='y'&&ch!='Y') { printf("\n输入错误!请重新输入:"); scanf("%s",&ch); } if(ch!='n'&&ch!='N') { namechange(a,n); } return; } else { while((strcmp(p1->data.name,s)!=0)&&p1->next!=NULL) p1=p1->next; if(p1->next ==NULL&&strcmp(p1->data.name,s) != 0) { printf("\n通讯录中没有此人!\n"); printf("\n是否继续修改?(Y/N)"); scanf("%s",&ch); while(ch!='n'&&ch!='N'&&ch!='y'&&ch!='Y') { printf("\n输入错误!请重新输入:"); scanf("%s",&ch); } if(ch!='n'&&ch!='N') { namechange(a,n); } return; } } if(strcmp(p1->data.name,s) == 0) { printf("类别:"); printf("%d\n",p1->data.fenlei); printf("姓名:"); printf("%s\n",p1->data.name); printf("电话:"); printf("%s\n",p1->data.tel); printf("电子邮件:"); printf("%s\n",p1->data.age); printf("QQ:"); printf("%s\n",p1->data.qq); printf("\n1.修改姓名\n"); printf("2.修改电话\n"); printf("3.修改电子邮件\n"); printf("4.修改地址\n"); printf("5.修改QQ号\n"); printf("0.返回菜单\n"); printf("请您选择(0-5):"); scanf("%d",&k); while(k!=1&&k!=2&&k!=3&&k!=4&&k!=5&&k!=0) { printf("\n输入错误,请重新选择:"); scanf("%d",&k); } switch(k) { case 1: printf("\n请输入新的姓名:"); scanf("%s",p1->data.name); break; case 2: printf("\n请输入新的电话:"); scanf("%s",p1->data.tel); break; case 3: printf("\n请输入新的电子邮件:"); scanf("%s",p1->data.age); break; case 5: printf("\n请输入新的QQ号:"); scanf("%s",p1->data.qq); break; case 0: return; } printf("\n修改成功!\n"); printf("\n是否继续修改?(Y/N)"); scanf("%s",&m); while(m!='n'&&m!='N'&&m!='y'&&m!='Y') { printf("\n输入错误!请重新输入:"); scanf("%c",&m); } for(; m=='y'||m=='Y';) { printf("请您选择(0-5):"); scanf("%d",&k); while(k!=1&&k!=2&&k!=3&&k!=4&&k!=5&&k!=0) { printf("\n输入错误,请重新选择:"); scanf("%d",&k); } switch(k) { case 1: printf("\n请输入新的姓名:"); scanf("%s",p1->data.name); break; case 2: printf("\n请输入新的电话:"); scanf("%s",p1->data.tel); break; case 3: printf("\n请输入新的电子邮件:"); scanf("%s",p1->data.age); break; case 5: printf("\n请输入新的QQ号:"); scanf("%s",p1->data.qq); break; case 0: return; } printf("\n修改成功!\n"); printf("\n是否继续修改?(Y/N)"); scanf("%s",&m); while(m!='n'&&m!='N'&&m!='y'&&m!='Y') { printf("\n输入错误!请重新输入:"); scanf("%s",&m); } } if(m=='n'||m=='N'); return; } } int main() { int ads,asd; Readfile(); while(1) { switch(ads=menu()) { case 1: system("cls"); print111(a); break; case 2: system("cls"); Save(); break; case 3: system("cls"); asd=select(); delete11(a,asd); break; case 4: system("cls"); asd=select(); namechange(a,asd); break; case 5: system("cls"); asd=select(); input1(a,asd); break; case 6: system("cls"); asd=select(); namefind(a,asd); break; case 0: system("cls"); exit(0); default: ads=menu(); } } }
c语言数据结构词索引表出了点问题,谁能帮忙看看呀
#include<stdio.h> #include<string.h> #include<stdlib.h> #include <conio.h> #include <ctype.h> #define OK 1 #define ERROR 0 #define TRUE 1 #define FALSE 0 #define OVERFLOW -2 #define MaxBookNum 1000 //假设只对1000本书建立索引表(1000) #define MaxKeyNum 2500 //索引表的最大容量(2500) #define MaxLineLen 500 //书目串的最大长度(500) #define MaxWordNum 10 //词表的最大容量 #define MaxWordLength 30 //单词的最大长度 typedef int Status; typedef int ElemType; //定义链表的数据元素类型为整型 typedef int Boolean; typedef struct { char item[MaxWordNum][MaxWordLength]; //字符串的数组 int last; //词表的长度 }WordListType; //词表的类型(顺序表) typedef struct { char *ch; //如果是非空串,则按串长分配存储区,否则ch为NULL int length; //串长度 }HString; typedef struct LNode { ElemType data; struct LNode *next; }LNode,*Link,*Position; typedef struct { Link head,tail; int len; }LinkList; typedef struct { HString key; //关键词 LinkList bnolist; //存放书号索引的链表 }IdxTermType; //索引项类型 typedef struct { IdxTermType item[MaxKeyNum+1]; int last; }IdxListType; //索引表类型 //----------------主要变量-------------- char buf[MaxLineLen]; //书目串缓冲区 WordListType wdlist; //关键字词表 IdxListType idxlist; //索引表 char oftenwords[6][10] = {"an","a","of","and","to","the"}; /*******************************声明部分****************************************/ //--------------基本操作--------- void InitIdxList (IdxListType *idxlist); //初始化操作,置索引表idxlist为空表,且在idxlist.item[0]设一空串 void GetLine (FILE *f); //从文件F读入一个书目信息到书目串缓冲区buf void ExtractKeyWord (int *Num); //Status ExtractKeyWord(char* Buffer,WordListType *w,int *Num); //从buf中提取书名关键词到词表wdlist,书号存入bno Status InsIdxList (IdxListType *idxlist,ElemType bno); //将书号为bno的书名关键词按词典顺序插入索引表idxlist void PutText (FILE *g,IdxListType idxlist); //将生成的索引表idxlist输出到文件g //--------------为实现在索引表上进行插入,要先实现下列操作----------- void GetWord (int i,HString *wd); //用wd返回词表wdist中第i个关键词 int Locate (IdxListType *idxlist,HString wd,Boolean *b); //在索引表idxlist中查询是否存在与wd相等的关键词。若存在,则返回其在索引表 //中的位置,且b取值TRUE;否则返回插入位置,且b取值FALSE void InsertNewKey(int j,HString wd); //在索引表idxli的第i项上插入新关键词wd,并初始化书号索引的链表为空表 Status InsertBook (int i,int bno); //在索引表idxlist的第i项中插入书号为bno的索引 //------------串的堆分配存储表示----------- Status StrAssign(HString *T,char *chars); //生成一个其值等于串常量chars的串T int StrCompare(HString S,HString T); //若S>T,则返回值>0,若S=T,则返回值 = 0,若S<T,则返回值<0 Status StrCopy(HString *T, HString S); //由串S复制得串T //----------------带头结点的线性链表------------- Status InitList(LinkList *L); //构造一个空的线性链表L Status MakeNode(Link *p,ElemType e); //分配由p指向值e的结点,并返回OK;若分配失败,则返回ERROR Status Append (LinkList *L,Link s); //将指针s所指的一串结点链接在线性链表L的最后一个结点 //之后,改变链表L的尾指针指向新的尾结点 /*******************************函数部分****************************************/ Status StrAssign(HString *T,char *chars) { int i = strlen(chars); if((*T).ch) free((*T).ch); if(!i){ //若chars为空 (*T).ch = NULL; (*T).length = 0; } else{ //chars不空 if(!((*T).ch = (char *)malloc(i * sizeof(char)))) //为T分配chars所需的存储空间 exit(OVERFLOW); int count; for(count = 0;count <= i;count++) //把chars存入T中 (*T).ch[count] = chars[count]; (*T).length = i; } //else return OK; } void InitString(HString *T) { (*T).length = 0; (*T).ch = NULL; } int StrCompare(HString S,HString T) { int count; for(count = 0;count<S.length && count<T.length;count++){ if(S.ch[count] != T.ch[count]) return S.ch[count]-T.ch[count] ; } return S.length-T.length; } Status StrCopy(HString *T, HString S) { int j; if((*T).ch) free((*T).ch); //删除T串中原有值 (*T).ch = (char*)malloc(S.length * sizeof(char)); if(!(*T).ch) exit(OVERFLOW); for(j = 0; j <= S.length; j++) (*T).ch[j] = S.ch[j]; (*T).length = S.length; return OK; } Status InitList(LinkList *L) { Link p; p = (Link)malloc(sizeof(LNode)); if(!p) exit(OVERFLOW); p->next = NULL; (*L).head = (*L).tail = p; (*L).len = 0; return OK; } Status MakeNode(Link *p,ElemType e) { *p = (Link)malloc(sizeof(LNode)); if(!(*p)) exit(OVERFLOW); (*p)->data = e; (*p)->next = NULL; return OK; } Status Append (LinkList *L,Link s) { int i = 1; (*L).tail->next = s; while(s->next){ s = s->next; i++; } (*L).tail = s; (*L).len += i; return OK; } void GetWord(int i,HString *wd) { char *p; p = *(wdlist.item +i); StrAssign(wd,p); //生成关键字字符串 } int Locate(IdxListType *idxlist,HString wd,Boolean *b) { int i,m; for(i = (*idxlist).last-1; ( m=StrCompare((*idxlist).item[i].key,wd) ) >0; --i); if(m == 0){ //找到 *b = TRUE; return i; } else{ *b = FALSE; return i+1; } } void InsertNewKey(int j,HString wd) { int count; InitList(&idxlist.item[idxlist.last+1].bnolist); for(count = idxlist.last-1; count>=j; --count){ //后移索引项 idxlist.item[count+1] = idxlist.item[count]; } InitString(&idxlist.item[j].key); StrCopy(&idxlist.item[j].key,wd); //插入新的索引项 //串赋值 InitList(&idxlist.item[j].bnolist); //初始化书号索引表为空表 ++idxlist.last; } Status InsertBook (int i,int bookno) { Link p; if(!MakeNode(&p,bookno)) return ERROR; Append(&idxlist.item[i].bnolist,p); return OK; } Status InsertIdxList(IdxListType *idxlist,int bno) { int i,j; HString wd; Boolean b; InitString(&wd); for(i= 0;i<wdlist.last;++i){ GetWord(i,&wd); //获取wdlist中保存的单词 j = Locate(idxlist,wd,&b); //查找是否已存在于idxlist中 if(!b) //不存在 InsertNewKey(j,wd); //则插入新的关键词 InsertBook(j,bno); //插入书号 } return OK; } void InitIdxList (IdxListType *idxlist) { int i; (*idxlist).last = 0; for(i = 0;i<MaxKeyNum;i++){ InitList(&(*idxlist).item[i].bnolist); //初始化索引表项目中的书号的链表 } } void ExtractKeyWord (int *BookNum) { int i = 0,j = 0,k = 0,m; wdlist.last = 0; //很重要 Boolean Ignore; char TempChar[30]; for(m = 0;m<=30;m++) TempChar[m] = '\0'; //清空TempChat[] while(*(buf+i) !=' '){ //提取书目串缓冲区其中的书号 TempChar[i] = *(buf+i); //将书号以字符串类型保存在该数组中 i++; } TempChar[i] ='\0'; *BookNum = atoi(TempChar); //将书号转为int for(m = 0;m<=i;m++) TempChar[m] ='\0'; //清空TempChat[] i++; //推进一位,当前*(buf+i)开始为书名 while(*(buf+i) !='\n' && *(buf+i) != '\0'){ //每个字符串末尾都有结束符\n if(*(buf+i) != ' '){ //若非空字符 if(*(buf+i) >'A'&& *(buf+i) <= 'Z'){ *(buf+i) -= 'A' - 'a'; //若为大写,则转为小写 } TempChar[j] = *(buf+i); //把当前字符加入TempChar中//------------ j++; i++; } //if else{ //若为空字符,则检索当前TempChar中保存的字符串是否为常用词 Ignore = FALSE; //若Ignore为TRUE,则为常用词;为FALSE则不是常用词 for(m = 0;m<6;m++){ //查找是否为常用词 if(strcmp(TempChar,oftenwords[m]) == 0){ Ignore = TRUE; //是常用词 break; }//if }//for if(Ignore){ for(m = 0;m<=j;m++) TempChar[m] = '\0'; //清空TempChat[] i++; j = 0; }//if else{ //不是常用词 for(m = 0;m<=j;m++) //将该词插入wdlist中 wdlist.item[wdlist.last][m] = TempChar[m]; for(m = 0;m<=j;m++) TempChar[m] = '\0'; //清空TempChat[] k++; wdlist.last++; i++; j=0; }//else }//else }//while } void GetLine(FILE *f) { fgets(buf,MaxLineLen,f); } void PutText (FILE *g,IdxListType idxlist) { int i,j,k; Link p; for(i = 0;i<=idxlist.last;i++){ for(j = 0;j<idxlist.item[i].key.length; j++) putc(*(idxlist.item[i].key.ch + j),g); putc('\t',g); if(idxlist.item[i].key.length < 8) putc('\t',g); p = idxlist.item[i].bnolist.head; for(k = 0;k<idxlist.item[i].bnolist.len ; k++){ p = p->next; fprintf(g,"%03d",p->data); putc(' ',g); }//for putc('\n',g); }//for } void PrintFile(FILE *FileName) { char ch; rewind(FileName); ch = getc(FileName); while(ch != EOF){ putchar(ch); ch = getc(FileName); } printf("\n"); rewind(FileName); } /*******************************主函数部分**************************************/ int main() { FILE *f,*g; int ct; int BookNo; if((f = fopen("BookName.txt","r")) == NULL){ printf("ERROR in open BookName.txt\n"); exit(1); } if((g = fopen("KeyWordIndex_self.txt","w"))==NULL){ printf("ERROR in open KeyWordIndex_self.txt\n"); exit(1); } printf("书单文件:\n"); PrintFile(f); InitIdxList(&idxlist); WordListType w; while(!feof(f)){ GetLine(f); //读取书单文件中的一行到缓冲区 ExtractKeyWord(&BookNo); InsertIdxList(&idxlist,BookNo); } PutText(g,idxlist); fclose(f); fclose(g); printf("\n结果如下:\n"); if((g = fopen("KeyWordIndex_self.txt","r"))==NULL){ printf("ERROR in open KeyWorkIndex_self.txt\n"); exit(1); } PrintFile(g); fclose(g); return 0; }
爬虫福利二 之 妹子图网MM批量下载
爬虫福利一:27报网MM批量下载    点击 看了本文,相信大家对爬虫一定会产生强烈的兴趣,激励自己去学习爬虫,在这里提前祝:大家学有所成! 目标网站:妹子图网 环境:Python3.x 相关第三方模块:requests、beautifulsoup4 Re:各位在测试时只需要将代码里的变量 path 指定为你当前系统要保存的路径,使用 python xxx.py 或IDE运行即可。
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
Elastic:菜鸟上手指南
您们好,我是Elastic的刘晓国。如果大家想开始学习Elastic的话,那么这里将是你理想的学习园地。在我的博客几乎涵盖了你想学习的许多方面。在这里,我来讲述一下作为一个菜鸟该如何阅读我的这些博客文章。 我们可以按照如下的步骤来学习: 1) Elasticsearch简介:对Elasticsearch做了一个简单的介绍 2) Elasticsearch中的一些重要概念:cluster, n
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、PDF搜索网站推荐 对于大部
为啥国人偏爱Mybatis,而老外喜欢Hibernate/JPA呢?
关于SQL和ORM的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行了一番讨论,感触还是有一些,于是就有了今天这篇文。 声明:本文不会下关于Mybatis和JPA两个持久层框架哪个更好这样的结论。只是摆事实,讲道理,所以,请各位看官勿喷。 一、事件起因 关于Mybatis和JPA孰优孰劣的问题,争论已经很多年了。一直也没有结论,毕竟每个人的喜好和习惯是大不相同的。我也看
Java知识体系最强总结(2020版)
更新于2020-01-05 18:08:00 本人从事Java开发已多年,平时有记录问题解决方案和总结知识点的习惯,整理了一些有关Java的知识体系,这不是最终版,会不定期的更新。也算是记录自己在从事编程工作的成长足迹,通过博客可以促进博主与阅读者的共同进步,结交更多志同道合的朋友。特此分享给大家,本人见识有限,写的博客难免有错误或者疏忽的地方,还望各位大佬指点,在此表示感激不尽。 整理的Ja
计算机专业的书普遍都这么贵,你们都是怎么获取资源的?
介绍几个可以下载编程电子书籍的网站。 1.Github Github上编程书资源很多,你可以根据类型和语言去搜索。推荐几个热门的: free-programming-books-zh_CN:58K 星的GitHub,编程语言、WEB、函数、大数据、操作系统、在线课程、数据库相关书籍应有尽有,共有几百本。 Go语言高级编程:涵盖CGO,Go汇编语言,RPC实现,Protobuf插件实现,Web框架实
卸载 x 雷某度!GitHub 标星 1.5w+,从此我只用这款全能高速下载工具!
作者 | Rocky0429 来源 | Python空间 大家好,我是 Rocky0429,一个喜欢在网上收集各种资源的蒟蒻… 网上资源眼花缭乱,下载的方式也同样千奇百怪,比如 BT 下载,磁力链接,网盘资源等等等等,下个资源可真不容易,不一样的方式要用不同的下载软件,因此某比较有名的 x 雷和某度网盘成了我经常使用的工具。 作为一个没有钱的穷鬼,某度网盘几十 kb 的下载速度让我
复习一周,京东+百度一面,不小心都拿了Offer
你知道的越多,你不知道的越多 点赞再看,养成习惯 本文 GitHub https://github.com/JavaFamily 已收录,有一线大厂面试点思维导图,也整理了很多我的文档,欢迎Star和完善,大家面试可以参照考点复习,希望我们一起有点东西。 前言 还记得我上周说的重庆邮电研二的读者么? 、 知道他拿了Offer之后我也很开心,我就想把它的面试经历和面试题分享出来
毕业5年,我问遍了身边的大佬,总结了他们的学习方法
你知道的越多,你不知道的越多 点赞再看,养成习惯 本文 GitHub https://github.com/JavaFamily 已收录,有一线大厂面试点思维导图,也整理了很多我的文档,欢迎Star和完善,大家面试可以参照考点复习,希望我们一起有点东西。 前言 很多次小伙伴问到学习方法,我也很想写这样的一篇文章来跟大家讨论下关于学习方法这件事情。 其实学习方法这个事情,我没啥发言权
推荐10个堪称神器的学习网站
每天都会收到很多读者的私信,问我:“二哥,有什么推荐的学习网站吗?最近很浮躁,手头的一些网站都看烦了,想看看二哥这里有什么新鲜货。” 今天一早做了个恶梦,梦到被老板辞退了。虽然说在我们公司,只有我辞退老板的份,没有老板辞退我这一说,但是还是被吓得 4 点多都起来了。(主要是因为我掌握着公司所有的核心源码,哈哈哈) 既然 4 点多起来,就得好好利用起来。于是我就挑选了 10 个堪称神器的学习网站,推
这些软件太强了,Windows必装!尤其程序员!
Windows可谓是大多数人的生产力工具,集娱乐办公于一体,虽然在程序员这个群体中都说苹果是信仰,但是大部分不都是从Windows过来的,而且现在依然有很多的程序员用Windows。 所以,今天我就把我私藏的Windows必装的软件分享给大家,如果有一个你没有用过甚至没有听过,那你就赚了......,这可都是提升你幸福感的高效率生产力工具哦! 走起!...... NO、1 ScreenToGif 屏幕,摄像头和
大学四年因为知道了这32个网站,我成了别人眼中的大神!
依稀记得,毕业那天,我们导员发给我毕业证的时候对我说“你可是咱们系的风云人物啊”,哎呀,别提当时多开心啦......,嗯,我们导员是所有导员中最帅的一个,真的...... 不过,导员说的是实话,很多人都叫我大神的,为啥,因为我知道这32个网站啊,你说强不强......,这次是绝对的干货,看好啦,走起来! PS:每个网站都是学计算机混互联网必须知道的,真的牛杯,我就不过多介绍了,大家自行探索,觉得没用的,尽管留言吐槽吧?
看完这篇HTTP,跟面试官扯皮就没问题了
我是一名程序员,我的主要编程语言是 Java,我更是一名 Web 开发人员,所以我必须要了解 HTTP,所以本篇文章就来带你从 HTTP 入门到进阶,看完让你有一种恍然大悟、醍醐灌顶的感觉。 最初在有网络之前,我们的电脑都是单机的,单机系统是孤立的,我还记得 05 年前那会儿家里有个电脑,想打电脑游戏还得两个人在一个电脑上玩儿,及其不方便。我就想为什么家里人不让上网,我的同学 xxx 家里有网,每
史上最全的IDEA快捷键总结
写在前面: 我是 扬帆向海,这个昵称来源于我的名字以及女朋友的名字。我热爱技术、热爱开源、热爱编程。技术是开源的、知识是共享的。 这博客是对自己学习的一点点总结及记录,如果您对 Java、算法 感兴趣,可以关注我的动态,我们一起学习。 用知识改变命运,让我们的家人过上更好的生活。 相关文章: Idea 中最常用的10款插件,提高开发效率 Eclipse 最牛逼的 10 组快捷键,提高开发效率
阿里程序员写了一个新手都写不出的低级bug,被骂惨了。
你知道的越多,你不知道的越多 点赞再看,养成习惯 本文 GitHub https://github.com/JavaFamily 已收录,有一线大厂面试点思维导图,也整理了很多我的文档,欢迎Star和完善,大家面试可以参照考点复习,希望我们一起有点东西。 前前言 为啥今天有个前前言呢? 因为你们的丙丙啊,昨天有牌面了哟,直接被微信官方推荐,知乎推荐,也就仅仅是还行吧(心里乐开花)
一文带你看清 HTTP 所有概念
上一篇文章我们大致讲解了一下 HTTP 的基本特征和使用,大家反响很不错,那么本篇文章我们就来深究一下 HTTP 的特性。我们接着上篇文章没有说完的 HTTP 标头继续来介绍(此篇文章会介绍所有标头的概念,但没有深入底层) HTTP 标头 先来回顾一下 HTTP1.1 标头都有哪几种 HTTP 1.1 的标头主要分为四种,通用标头、实体标头、请求标头、响应标头,现在我们来对这几种标头进行介绍 通用
作为一个程序员,CPU的这些硬核知识你必须会!
CPU对每个程序员来说,是个既熟悉又陌生的东西? 如果你只知道CPU是中央处理器的话,那可能对你并没有什么用,那么作为程序员的我们,必须要搞懂的就是CPU这家伙是如何运行的,尤其要搞懂它里面的寄存器是怎么一回事,因为这将让你从底层明白程序的运行机制。 随我一起,来好好认识下CPU这货吧 把CPU掰开来看 对于CPU来说,我们首先就要搞明白它是怎么回事,也就是它的内部构造,当然,CPU那么牛的一个东
【综合篇】浏览器的工作原理:浏览器幕后揭秘
web(给达达前端加星标,提升前端技能) 了解浏览器是如何工作的,能够让你站在更高的角度去理解前端 浏览器的发展历程的三大路线,第一是应用程序web化,第二是web应用移动化,第三是web操作系统化。是不是有点不直白。 应用程序web化就是随着现在技术的发展,现在越来越多的应用转向了浏览器与服务器,就是B/S架构;web应用移动化,就是在移动设备应用,什么是移动设备呢。 “移动设备:
破14亿,Python分析我国存在哪些人口危机!
2020年1月17日,国家统计局发布了2019年国民经济报告,报告中指出我国人口突破14亿。 猪哥的朋友圈被14亿人口刷屏,但是很多人并没有看到我国复杂的人口问题:老龄化、男女比例失衡、生育率下降、人口红利下降等。 今天我们就来分析一下我们国家的人口数据吧! 更多有趣分析教程,扫描下方二维码关注vx公号「裸睡的猪」 即可查看! 一、背景 1.人口突破14亿 2020年1月17日,国家统计局发布
作为一个程序员,内存和磁盘的这些事情,你不得不知道啊!!!
截止目前,我已经分享了如下几篇文章: 一个程序在计算机中是如何运行的?超级干货!!! 作为一个程序员,CPU的这些硬核知识你必须会! 作为一个程序员,内存的这些硬核知识你必须懂! 这些知识可以说是我们之前都不太重视的基础知识,可能大家在上大学的时候都学习过了,但是嘞,当时由于老师讲解的没那么有趣,又加上这些知识本身就比较枯燥,所以嘞,大家当初几乎等于没学。 再说啦,学习这些,也看不出来有什么用啊!
这个世界上人真的分三六九等,你信吗?
偶然间,在知乎上看到一个问题 一时间,勾起了我深深的回忆。 以前在厂里打过两次工,做过家教,干过辅导班,做过中介。零下几度的晚上,贴过广告,满脸、满手地长冻疮。 再回首那段岁月,虽然苦,但让我学会了坚持和忍耐。让我明白了,在这个世界上,无论环境多么的恶劣,只要心存希望,星星之火,亦可燎原。 下文是原回答,希望能对你能有所启发。 如果我说,这个世界上人真的分三六九等,...
B 站上有哪些很好的学习资源?
哇说起B站,在小九眼里就是宝藏般的存在,放年假宅在家时一天刷6、7个小时不在话下,更别提今年的跨年晚会,我简直是跪着看完的!! 最早大家聚在在B站是为了追番,再后来我在上面刷欧美新歌和漂亮小姐姐的舞蹈视频,最近两年我和周围的朋友们已经把B站当作学习教室了,而且学习成本还免费,真是个励志的好平台ヽ(.◕ฺˇд ˇ◕ฺ;)ノ 下面我们就来盘点一下B站上优质的学习资源: 综合类 Oeasy: 综合...
死磕Lambda表达式(二):Lambda的使用
在哪使用Lambda表达式?怎么样正确的使用Lambda表达式?
史上最牛逼的 Eclipse 快捷键,提高开发效率!
如果你在使用IDEA,请参考博主另外的一篇idea快捷键的博客。
在三线城市工作爽吗?
我是一名程序员,从正值青春年华的 24 岁回到三线城市洛阳工作,至今已经 6 年有余。一不小心又暴露了自己的实际年龄,但老读者都知道,我驻颜有术,上次去看房子,业务员肯定地说:“小哥肯定比我小,我今年还不到 24。”我只好强颜欢笑:“你说得对。” 从我拥有记忆到现在进入而立之年,我觉得,我做过最明智的选择有下面三个: 1)高中三年,和一位女同学保持着算不上朋友的冷淡关系;大学半年,把这位女同学追到...
CSS操作之你不得不知的一些小技巧(一)ヾ(Ő∀Ő๑)ノ太棒了!!
目录 CSS单行/多行文本,超出隐藏并显示省略号 1. CSS单行/多行文本,超出隐藏并显示省略号 方法一:使用CSS属性 单行文本溢出显示省略号 width: 100px; overflow: hidden; text-overflow:ellipsis; //文本溢出显示省略号 white-space: nowrap; //文本不会换...
强烈推荐 10 款珍藏的 Chrome 浏览器插件
Firebug 的年代,我是火狐(Mozilla Firefox)浏览器的死忠;但后来不知道为什么,该插件停止了开发,导致我不得不寻求一个新的网页开发工具。那段时间,不少人开始推荐 Chrome 浏览器,我想那就试试吧,期初我觉得用起来很别扭,毕竟我不是一个“喜新厌旧”的人。但用的次数越来越多,也就习惯了。 Chrome 浏览器有一个好处,就是插件极其丰富,只有你想不到的,没有你找不到的,这恐怕是...
我以为我对数据库索引十分了解,直到我遇到了阿里面试官。
索引的数据结构分析,数据库面试到索引最常见的问题分析,我总结了一下。
Java程序员都需要懂的「反射」
前言 只有光头才能变强。 文本已收录至我的GitHub精选文章,欢迎Star:https://github.com/ZhongFuCheng3y/3y 今天来简单写一下Java的反射。本来没打算写反射这个知识点的,只是不少的读者都问过我:“你的知识点好像缺了反射阿。能不能补一下?” 这周末也有点空了,所以来写写我对反射的简单理解。这篇是入门文章,没有高深的知识点,希望能对新人有帮助。如果...
史上最牛逼的 VSCode 插件,提高开发效率!
这篇文章收集了一些常用的vscode插件,提高开发效率。
Java第二周学习
Java第二周学习 1. 数组 1.1 定义数组格式 数据类型[] 数组名 = new 数据类型[容量]; int[] arr = new int[10]; 赋值左侧 数据类型: 告知编译器,当前数组中能够保存的数据类型到底是什么?并且在确定数据类型之后,整个数组中保存的数据类型无法修改!!! []: 告知编译器这里定义的是一个数组类型数据。 明确告知编译器,数组名是一个【引用数据类型...
有没有简单一点的 Python 小例子或小项目?
分享一波Github上适合新手入门、又十分有趣的Python项目~ 1. 人脸识别 star:30.5k 最简洁的人脸识别库。可以使用Python和命令行工具提取、识别、操作人脸。其人脸识别是基于业内领先的C++开源库dlib中的深度学习模型,用Labeled Faces in the Wild人脸数据集进行测试,准确率高达99.38%。 而且有中文版README哟~ 2. faceai sta...
看完这篇JVM,阿里面试官都不怕!
前言 只有光头才能变强 本已收录至我的GitHub精选文章,欢迎Star:https://github.com/ZhongFuCheng3y/3y 学习JVM的目的也很简单: 能够知道JVM是什么,为我们干了什么,具体是怎么干的。能够理解到一些初学时不懂的东西 在面试的时候有谈资 能装逼 (图片来源:https://zhuanlan.zhihu.com/p/25511795,侵删) 声...
隆重向你推荐这 8 个开源 Java 类库
昨天在青铜时代群里看到读者朋友们在讨论 Java 最常用的工具类,我觉得大家推荐的确实都挺常见的,我自己用的频率也蛮高的。恰好我在 programcreek 上看到过一篇类似的文章,就想着梳理一下分享给大家。 在 Java 中,工具类通常用来定义一组执行通用操作的方法。本篇文章将会向大家展示 8 个工具类以及它们最常用的方法,类的排名和方法的排名均来自可靠的数据,从 GitHub 上最受欢迎的 ...
Java基础知识面试题(2020最新版)
文章目录Java概述何为编程什么是Javajdk1.5之后的三大版本JVM、JRE和JDK的关系什么是跨平台性?原理是什么Java语言有哪些特点什么是字节码?采用字节码的最大好处是什么什么是Java程序的主类?应用程序和小程序的主类有何不同?Java应用程序与小程序之间有那些差别?Java和C++的区别Oracle JDK 和 OpenJDK 的对比基础语法数据类型Java有哪些数据类型switc...
Spring面试题(2020最新版)
文章目录Spring概述(10)什么是spring?Spring框架的设计目标,设计理念,和核心是什么Spring的优缺点是什么?Spring有哪些应用场景Spring由哪些模块组成?Spring 框架中都用到了哪些设计模式?详细讲解一下核心容器(spring context应用上下文) 模块Spring框架中有哪些不同类型的事件Spring 应用程序有哪些不同组件?使用 Spring 有哪些方式...
用树莓派做一个人脸识别开锁应用
作者:eckygao,腾讯 CSIG 云产品部1.案例概述1.1 背景实现一个人脸识别进行开锁的功能,用在他的真人实景游戏业务中。总的来说,需求描述简单,但由于约束比较多,在架构与选型上...
C语言写个贪吃蛇游戏
贪吃蛇是个非常经典的游戏,用C语言来实现也是一个好玩的事情。这个游戏我写完后放在知乎,竟然点赞的人数超级多。我觉得大家喜欢,一个方面是因为写得简单,大家都能看得懂,一个可扩展性还是非常强...
出不了门的日子,我选择在 GitHub 上快乐的打游戏
作者 | Rocky0429 来源 | Python空间 大家好,我是 Rocky0429,一个在家憋到长蘑菇的蒟蒻… 2020 年的开年因为一些大家都知道的原因,有些不顺,但还是要捏捏自己的脸蛋儿,微笑的面对,毕竟日子还是要过下去… 要点脸皮,不能出门,假期又一延再延,作为一个从小熟读结发悬梁铁锥刺骨囊萤照读牛角挂书等典故的社会主义好青年,我决定趁这段时间好好充实自己,争取早日上...
7年加工作经验的程序员,从大厂跳槽出来,遭遇了什么?
引言      很久没写文章了,只是隔一两个月更新篇小说,回想起来,LZ至今工作也8年了,回想起来,一时间难免感慨,时间真的过的太快了。   当初在北京的4年多,是LZ工作中最精彩的一段经历,这也是为何LZ的小说以LZ在北京打拼时的真实经历为背景,因为那是一段难忘而又精彩的时光。   16年偶得一个大厂的offer,因此LZ就毅然决然的来到了杭州,来到杭州以后,LZ的工作平淡了许多,或许和...
为什么大多数人永远不会真正成功?
前几天看到一个叫做《为什么大多数人永远不会真正成功?》的视频,我本来以为是鸡汤,耐着性子看了一个开头,立刻被吸引了,居然一口气看完了。看完了以后,我对照着自己这10多年的经历反思了一下...
一篇文章带你入门爬虫丶刷网课丶刷文章阅读量丶刷刷刷。
走过路过不要错过,学不会没关系,长点见识也是可以的啦。 简介 博主于17年开始自学的python, 期间做过各个领域的python开发,包括爬虫, web, 硬件, 桌面应用, AI, 数据分析。 可能有人会问python能做硬件开发?可自行搜索pyboard丶树莓派丶MicroPython, 描述python最有精髓的一句话: python 除了不能生孩子, 啥都能干。 通过该篇文章,读者可以...
Python3怎么处理Excel中的数据(xlrd、xlwt的使用方法)
最近在做毕设,需要把Excel中的数据进行处理,但是。。有346469条数据,不能每一条都自己进行运算并且将它进行归一化运算
python --图像处理基础
一、PIL-Python图像库 二、 三、
疫情期间,天天对着你“开枪”的额温枪,你知道它的工作原理吗?
冠状病毒疫情期间,大家都知道口罩脱销了,消毒酒精脱销了,其实医用的额温枪也脱销了,一枪难求,因为其快速测温(1秒测温),无接触测温的特点,在很多地方被广泛使用,额温枪成了名副其实的防疫物质,此篇博客讲述额温枪的工作原理。
相关热词 c# singleton c#中类的默认值是 c#各种进制之间的转换 c# 正则表达式保留汉字 c#后台跨域 c#基础代码大全 c#指定combox选择 c#关系 mono c# 相差毫秒 用c#做一个简易计算器
立即提问