C语言 关于读文件及如何实现输入文件中已存在的信息则不允许被添加

我写的一个关于添加书籍信息的函数,但实现不了(若书名已经存在,则不允许添加该信息。)这个条件,求问大神是哪里的问题

#include
#include
#include

typedef struct book
{
char book_name[20];
char book_writer[10];
char publisher[30];
char publishdate[10];
int price;
int quantity;
int stock;

}BOOK;

void insert_Book()
{
FILE *fp;
int n=0;
BOOK bk;
while(n==0)
{
printf("\n请输入新书信息...\n包括书名.作者.出版商.出版日期.价格\n");
printf("书名:\n");
scanf("%s",bk.book_name);
printf("作者:\n");
scanf("%s",bk.book_writer);
printf("出版商:\n");
scanf("%s",bk.publisher);
printf("出版日期:\n");
scanf("%s",bk.publishdate);
printf("价格:\n");
scanf("%d",&bk.price);
bk.stock=0;
printf("\n请选择(1:确定\t2:取消\t0:重新输入):");
scanf("%d",&n);
}
if(n==1)
{
if((fp=fopen("bookinfo.txt","a"))==NULL)
{
printf("无法打开文件!");
return;
}
fprintf(fp,"%s %s %s %s %d %d\n",bk.book_name,bk.book_writer,bk.publisher,bk.publishdate,bk.price,bk.stock);
fclose(fp);
}
system("CLS");
printf("输入成功!\n");
printf("请选择(1:返回主界面\t2:输入另一本图书信息\t0:退出系统):\n");
scanf("%d",&n);
switch(n)
{
case 1:system("CLS");break;
case 2:system("CLS");
smcf();
break;
case 0:break;
default:printf("无此操作,按任意键返回\n");
system("CLS");
break;
}
}

int smcf()//书名重复的情况
{
char filename[20]="C:\bookinfo.txt"; //存放书籍信息的文件
FILE * in;
char c,d;
char name[20]={0}; //存放输入的书籍名称
BOOK book,tmp;
int i=0;
printf("请输入书籍名称:");
d=getchar();
while((c=getchar())!='\n')
{
if(i>=20)
{
printf("书籍名称超过了20个字符,无法查询!\n");
return;
}
name[i++]=c;
}
if((in=fopen(filename,"r"))==NULL)//以只读方式打开文件
{

printf("文件%s无法打开,查询失败!\n",filename);
return;
}
i=0;
while(!feof(in))
{
fscanf(in,"%s\n",book.book_name);//存入书籍信息
if(ferror(in))
{
printf("文件读取错误,查询失败!\n");
clearerr(in);
return;
}
else//读取成功
{

if(strcmp(name,book.book_name)==0)//若输入的书籍名称与读出的书籍信息中的书籍名称相同
{

printf("书名已存在!不允许添加该信息!");
exit(0);
}
else
{
insert_Book();
}

    }
}
fclose(in);
return;

}

int main()

{
insert_Book();
return 0;
}


Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
C语言fopen打开文件失败
一个单链表创建学生信息的作业,要求要用文件的输入输出。 打全部路径会出现如图的错误。 打“C:\\\student_info.txt”也不行。 把文件移到project8的文件夹下面打“student_info.txt”也不行。 已确定文件在文件夹内是存在的。F11调试确定就是fopen那块儿出的问题 求问怎么改......崩溃 ![图片说明](https://img-ask.csdn.net/upload/201912/04/1575461393_230930.png) #define _CRT_SECURE_NO_DEPRECATE #include <stdio.h> #include <stdlib.h> #define OK 1 #define ERROR 0 #define OVERFLOW -2 typedef int ElemType; typedef int Status; FILE *fp; /*①单链表数据结构定义*/ typedef struct { int num; //学号 //char name[20]; //姓名 //int sex; //性别 //int dorm; //宿舍 //int tel; //电话 }Student; //结点定义 typedef struct LNode { Student data; struct LNode *next; }LNode; //链表定义 typedef struct { LNode* head; //指向头结点的指针 int length; //链表长度 }LinkList; /*②单链表基本操作接口定义*/ //初始化链表:创建头结点,给L字段赋初值 //返回一个空的单链表 Status InitList(LinkList &L); //初始条件:线性表L已经初始化 //采用头插法创建一个单链表,元素类型为整形,输入-9999时结束 Status CreateFromHead(LinkList &L); //初始条件:线性表L已经初始化 //采用尾插法创建一个单链表,元素类型为整形,输入-9999时结束 Status CreateFromTail(LinkList &L); //初始条件:线性表L已经存在 //打印出所有元素 void PrintElem(LinkList L); //初始条件:线性表L已经存在 //查找第i个结点,若找到(1≤i≤n),则由e返回其值 Status GetElem_L(LinkList L, int i, ElemType &e); //初始条件:线性表L已经存在 //在单链线性表L的第i个元素之前插入元素e Status ListInsert_L(LinkList &L, int i, ElemType e); //初始条件:线性表L已经存在 //删除第i个元素,并由e返回其值 Status ListDelete_L(LinkList &L, int i, ElemType &e); int main() { LinkList L; InitList(L); CreateFromHead(L); PrintElem(L); system("pause"); } /*③部分单链表操作的实现函数*/ Status InitList(LinkList &L) //初始化链表 { L.head = (LNode*)malloc(sizeof(LNode)); if (!L.head)exit(OVERFLOW); L.length = 0; L.head->next = NULL; return OK; } //初始条件:线性表L已经初始化 //采用头插法创建一个单链表,元素类型为整形,输入-9999时结束 Status CreateFromHead(LinkList &L) { LNode *s; int flag = 1; int e; L.head = (LNode*)malloc(sizeof(LNode)); L.head->next = NULL; while (flag) { fp = fopen("C:\Users\解诗雨\source\student_info.txt", "r+"); if (fp==NULL) { printf("打不开\n"); return OK; } fscanf(fp,"%d", &e); if (e) { s = (LNode*)malloc(sizeof(LNode)); s->data.num = e; s->next = L.head->next; L.head->next = s; ++L.length; } else flag = 0; fclose(fp); } return OK; } //初始条件:线性表L已经存在 //打印出所有元素 void PrintElem(LinkList L) { LNode* p; p = L.head->next; printf("当前的结点数为:%d\n", L.length); while (p) { printf("%4d ", p->data.num); p = p->next; } printf("\n"); } 文本: ![图片说明](https://img-ask.csdn.net/upload/201912/04/1575462569_672809.png) 因为现在还在创建链表其他还没弄完...
C语言fscanf文件输入时,文件中的文字到变量中变成乱码(?)
下面是用到的代码: //初始化链表 Status InitList(LinkList &L) { L.head = (LNode*)malloc(sizeof(LNode)); if (!L.head)exit(OVERFLOW); L.length = 0; L.head->next = NULL; return OK; } //尾插法创建单链表 Status CreateFromTail(LinkList &L) { LNode s,*r=L.head; s = (LNode)malloc(sizeof(LNode)); fp = fopen("C:/Users/名字/source/student_info.txt", "r"); if (fp==NULL) { printf("打不开\n"); return OK; } while (fscanf(fp, "%d\t\t%s\t\t%s\t\t%s\t\t%s\n", &s->data.num, s->data.name, s->data.sex, s->data.dorm, s->data.tel) != EOF) { s->next = r->next; r->next = s; r = s; ++L.length; s = (LNode*)malloc(sizeof(LNode)); } fclose(fp); return OK; } //打印文件 void PrintElem(LinkList L) { LNode* p; p = L.head->next; printf("当前的结点数为:%d\n", L.length); while (p) { printf("%d\t\t%s\t\t%s\t\t%s\t\t%s\n", p->data.num, p->data.name, p->data.sex, p->data.dorm, p->data.tel); p = p->next; } printf("\n"); } int main() { int n; LinkList L; InitList(L); CreateFromTail(L); PrintElem(L); } ![图片说明](https://img-ask.csdn.net/upload/201912/07/1575714315_137600.png) ![图片说明](https://img-ask.csdn.net/upload/201912/07/1575714332_236529.png) 比如前三个,汉字输出不一样了,但是后面字母是对的
c语言 文件程序设计 跪求谢谢大佬来解答
假设文件address.txt中已存放3位联系人信息,编写程序,从键盘输入1位联系人信息,序号:4,姓名:小鹿,性别:女,电话号码:15821889977,把该联系人添加到文件里。然后从文件中读出全部信息,并在屏幕上显示。![图片说明](https://img-ask.csdn.net/upload/201912/25/1577251897_143277.png)
C语言编写班级考勤管理(求哪位大神帮帮忙,要交ke's)
要用到链表 实现学生信息的增、删、改操作。可对班级学生按照课程进行考勤(类别:出勤、迟到、早退、缺席),并提供按照班级、学号、类别进行统计、查询、浏览等功能。 (要求:1.源文件采用多文件的工程结构2.数据存储采用文件形式3.标准的C输入输出4.功能完善,适当的注释,5.关于文件的内容需要自学) 还要有 一、需求分析 要求:本节是需求分析的部分,该节主要说明课程设计题目的具体要求,如:程序应具备的功能、程序设计时必须使用的数据结构(数组、动态链表、文件等)、程序运行时对输入输出格式的要求以及对程序运行性能的要求等,在撰写本节的文档时,对于以上的具体要求应详细地给出明确的说明。
C语言的文件中,数据以记录为界限,便于区分 ?
以下叙述中不正确的是 。 A.以二进制格式输出文件,则文件内容与内存中完全一致; B.定义:int n=123;若以ASCII文件的格式存放,变量n将在磁盘上占3个字节;C.C语言中,没有输入输出语句,对文件的读/写都是用库函数来实现的;D.C语言的文件中,数据以记录为界线,便于区分。 ===参考答案为D,求大侠详细解释
C 语言 EOF和文件读写及终止输入
我在C Primer Plus中看到这样一个例子用于终止输入的方法: ``` #include <stdio.h> int main() { int ch; while((ch=getchar())!=EOF) putchar(ch); return 0; } ``` 在这个地方使用的是EOF来终止,一般EOF是用于文件读写结尾的返回,end of file, 因为EOF的值是-1,而在标准字符集中没有-1对应的值,所以可以用其来现实文件的结尾。在大多数系统中有具有一种从键盘模拟文件结尾的方法。所以这个地方使用了 EOF作为输入结尾的标志 问题来了:我们在键盘中不能输入-1,那么程序是如何读取到的这个EOF,从而终止输入的呢?怎么上面这个程序能够有效的实现最终的这个输入终止呢? 我在windows平台上运行这个程序,由于没办法输入-1,所以没办法终止程序,在linux上键入Ctrl+Z(Ctrl+Z在一些系统中可以作为文件结尾的标志) 然后linux现实的是如下的样子![图片说明](https://img-ask.csdn.net/upload/201611/05/1478336619_474167.png) 求大神指点
汉字统计 C语言文件的运用
Problem Description 统计给定文本文件中汉字的个数。 Input 输入文件首先包含一个整数n,表示测试实例的个数,然后是n段文本。 Output 对于每一段文本,输出其中的汉字的个数,每个测试实例的输出占一行。 [Hint:]从汉字机内码的特点考虑~ Sample Input 2 WaHaHa! WaHaHa! 今年过节不说话要说只说普通话WaHaHa! WaHaHa! 马上就要期末考试了Are you ready? Sample Output 14 9
求助Fortran大神们,我读文件遇到了很奇怪的问题,百思不得其解,求助啦!
我的程序是读文件,然后将文件里的数据赋值给数组,再统计每一列数据中不同数字的个数,所以单独写了个子程序计算每一列中不同数据中的个数;我的程序一直到把文件中的数据赋值给数组都是对的,偏偏子程序那儿就出错了,就是统计出来这个文件有117行,并且我的数据里是没有0的,但是同列中不同数字出现的数量之和却不等于117,我一直找不到问题在哪里,但是之前我发现直接T=A(I,J),DAAN(J,T)=DAAN(J,T)+1,就回报错显示我DAAN越界了,说是T=0,但是我DAAN下届最小为1,即表示我A(I,J)有数字0,可是我不论是文件里还是屏幕输出的数组里,都没有0啊,求助大神呀! 附上我的代码: ```PROGRAM pichuli IMPLICIT NONE INTEGER::I,J,K,B,T INTEGER,DIMENSION(1:200,1:11)::WEN INTEGER,DIMENSION(1:11,1:11)::DAAN CHARACTER FNAME(11)*4 OPEN(10,FILE='list.txt') READ(10,*)(FNAME(I),I=1,11) WRITE(*,*)(FNAME(I),I=1,11) K=1 DAAN=0 DO 111 WHILE(K<12) !从DO开始循环,到语句111为1个循环,循环1-11次 OPEN(11,FILE=FNAME(K)//'.txt') !!!!!输入原始数据 B=0 DO 10 WHILE(.NOT.EOF(11)) !当文件不在末尾的时候执行此循环,从DO到10语句为一个循环。 B=B+1 READ(11,*) 10 CONTINUE CLOSE(11) B=B WRITE(*,*)B !B计算读的这个文件有多少行 OPEN(1,FILE=FNAME(K)//'.txt') !!!!输入原始数据 OPEN(2,FILE='JISHU.TXT')!!!生成新文件 T=0 DO 11 WHILE(.NOT.EOF(1)) !当文件不在末尾的时候执行此循环,从DO到11语句为一个循环。 IF(T==0)THEN READ(1,*) ELSE READ(1,*)(WEN(T,J),J=1,11) WRITE(*,100)(WEN(T,J),J=1,11) END IF T=T+1 11 CONTINUE CALL JISHU(WEN,DAAN,B) WRITE(2,102) DO J=1,11 !第J问 WRITE(2,101)(DAAN(J,I),I=1,11) !第J问选每个答案的人数 END DO K=K+1 100 FORMAT(11I3) 101 FORMAT(11(I6,2X)) 102 FORMAT(4X,'一',6X,'二',6X,'三',6X,'四',6X,'五',6X,'六',6X,'七',6X,'八',6X,'九',5X,'十',4X,'十一') 111 CONTINUE CLOSE(1) CLOSE(2) CLOSE(11) END SUBROUTINE JISHU(A,DAAN,B) INTEGER::I,J,T,B INTEGER,DIMENSION(1:11,1:11)::DAAN INTEGER,DIMENSION(1:B-1,1:11)::A DAAN=0 DO J=1,11 !第J题 DO I=1,B-1 !第I个答题人 IF(A(I,J)/=0)THEN T=A(I,J)!将第I个答题人的第J问的选项赋值给T DAAN(J,T)=DAAN(J,T)+1!第J问的第T选项+1 END IF END DO END DO END ``` ```
c语言 输入20个学生成绩
输入20个学生记录(每个学生记录包括学号,性名、性别、年龄、成绩),构成结构体数组,计算所有学生的平均分,找出最高分,找出所有不及格的学生,然后按成绩由高到低的排序结果写入文件中,最后读取文件,输出排序结果
如何用C语言删除一个文件?
如何用C语言删除一个文件?想用remove函数。从键盘上输入要删除的文件名。可不知如何编写,大师可否写个例子啊。
不知道为啥通过不了,输入到文件尾结束不知道为啥,求大神解决?
![图片说明](https://img-ask.csdn.net/upload/202002/23/1582443722_635834.png) ``` #include <stdio.h> int main() { int score[100],i; float sum,ave; sum=0.0; for( i =0;i<5;i++){ scanf("%d",&score[i]); sum=sum+score[i]; } ave=sum/5.0; printf("%.1f",ave); return 0; } ```
c语言编程:按照部分文件名查找文件
C语言编程:按照部分文件名查找文件,例如dfryibsbj.txt文件,输入yibs就可以找到这个文件,并且将这个文件拷贝到另一个文件夹的yibs.txt
C语言大量文件依次读写
悬赏求助一个小问题。我有一个简单的C语言程序,可以实现计算一个输入文件同时输出结果文件。现在想要计算大量不同的该输入文件,同时一一输出结果。有会的求指导一下,加好友492385974,
大佬们,请帮忙做到数据结构的题,用C++完成,谢谢大佬们!
1. 员工对象(包括姓名、账号、性别、年龄)这几个属性,有形如下的人员组织架构: A / \ B C / \ / \ D E F G / \ H I 1) 请用程序数据结构描述出来,组织结构中的人员用员工对象表示; 2) 编写一个方法,实现输入任何一个人员,按层次打印出自己及所有下属 如输入B,打印出: B --D ----H ----I --E 不用整的太复杂,第一题把类定义出来就行;第二题只打印字母,然后把结果存放在demo.txt文件中!
这是一个关于C语言 建立新cpp文件的问题 。
我想在main文件的基础上,再建立一个cpp子文件,但是呢。系统不让我写名字。我就感觉好奇怪,名字不应该随便起的吗? 下面是我操作的图![图片说明](https://img-ask.csdn.net/upload/201910/23/1571807636_238986.png) 我右击项目名,就那个排序代码,然后选择new class,弹出这个窗口,输入名字,然后神奇的出错了
有没有大神帮我看看哪里出错了?没输完信息,就自动结束的?未完成?
``` #include<stdio.h> #include<stdlib.h> #include<string.h> typedef struct stu { char name[10]; char guan[10]; char number1[20]; char number2[20]; char box[30]; }gs; typedef struct pgs { gs chat; pgs* next; }*ptgs; ptgs head=(ptgs)malloc(sizeof(pgs)); int denglu(); int fun1(); int fun2(); int fun3(); int fun4(); int app(char *p);//计算字符串长度! int main() { int i,a; head->next=NULL; printf("\n\n\t\t\t\t**************************************************************\n"); printf("\t\t\t\t\t\t\t通讯录管理系统\n"); printf("\t\t\t\t\t\t\t\t设计者:\n"); printf("\t\t\t\t**************************************************************\n"); printf("\t\t\t\t欢迎使用通讯录管理系统!!!!!!\n"); printf("\t\t\t\t继续请按 1 ,退出请按 0 !\n"); printf("\t\t\t\t请输入:"); for(i=0;i<2;i=1) { scanf("%d",&a); getchar(); switch(a) { case 1:denglu();break; case 0:break; default:printf("\t\t\t\t请重新输入:");continue; } break; } printf("\t\t\t\t系统即将退出!!!"); printf("\t\t\t\t谢谢使用!!!!!"); } int denglu() { int a,i,j,k; printf("\n\n"); printf("\t\t\t\t**************************************************************\n"); printf("\t\t\t\t\t\t\t>登陆界面<\n"); printf("\n\t\t\t\t\t\t\t登录请输入 1 !\n"); printf("\t\t\t\t\t\t\t注册请输入 2 !\n"); printf("\t\t\t\t\t\t\t退出请输入 0 !\n"); printf("\t\t\t\t请输入:"); for(i=0;i<2;i=1) { scanf("%d",&a); getchar(); switch(a) { case 1:fun1();break; case 2:fun2();break; case 0:break; default:printf("\t\t\t\t请重新输入:");continue; } break; } } int fun1()//登陆函数 { FILE *fp; int i,k; char e[81],f[81],a[81],b[81]; if((fp = fopen("D:\\w\\hao\\mm.txt","r"))==0) { printf("\t\t\t\t文件打开失败!!!!"); denglu(); } printf("\n\n\t\t\t\t**************************************************************"); printf("\n\t\t\t\t\t\t\t<>登陆<>\n"); printf("\n\t\t\t\t用户名:"); scanf("%s",e); printf("\n\t\t\t\t密码:"); scanf("%s",f); fscanf(fp,"%s %s",a,b); fclose(fp); if(strcmp(a,e)==0&&strcmp(b,f)==0) { printf("\n\t\t\t\t登陆成功!!!\n"); fun3(); } else { printf("\n\t\t\t\t用户名或密码错误!!\n"); printf("\t\t\t\t重新登陆请按 1 ,退出登陆请按 0 !\n"); printf("\t\t\t\t请选择:") ; for(i=1;i<2;i=1) { scanf("%d",&k); getchar(); switch(k) { case 1: fun1();break; case 0: denglu();break; default: printf("\t\t\t\t\t\t输入错误,请重新输入:"); continue; } break; } } system("pause"); } int fun2()//注册函数 { FILE *fp; int i,k; fp = fopen("D:\\w\\hao\\mm.txt","w"); char a[81],b[81],c[81]; printf("\n\n\t\t\t\t**************************************************************\n"); printf("\t\t\t\t\t\t\t<>注册界面<>\n"); printf("\n\t\t\t\t请输入用户名:"); scanf("%s",a); printf("\n\t\t\t\t请输入密码:"); scanf("%s",b); printf("\n\t\t\t\t请再次输入密码:"); scanf("%s",c); fputs(a,fp); fputs("\n",fp); fputs(b,fp); fclose(fp); if(strcmp(b,c)==0) { printf("\n\t\t\t\t注册成功!\n"); fun1(); } else { printf("\t\t\t\t输入的两次密码不一样,注册失败!\n"); printf("\t\t\t\t重新注册请输入 1 ,退出注册请输入 0 !"); for(i=1;i<2;i=1) { scanf("%d",&k); getchar(); switch(k) { case 1: fun2();break; case 0: denglu();break; default: printf("\t\t\t\t\t\t输入错误,请重新输入:"); continue; } break; } } system("pause"); } int fun3()//菜单 { int j; char k; printf("\n\n\t\t\t\t**************************************************************\n"); printf("\t\t\t\t\t\t\t<>功能中心<>\n"); printf("\n\t\t\t\t\t\t「\n"); printf("\t\t\t\t\t\t\t1.信息录入 \n"); printf("\t\t\t\t\t\t\t2.信息浏览 \n"); printf("\t\t\t\t\t\t\t3.信息查询 \n"); printf("\t\t\t\t\t\t\t4.信息修改 \n"); printf("\t\t\t\t\t\t\t5.退出系统 \n"); printf("\t\t\t\t\t\t\t 」\n"); printf("\t\t\t\t请输入相应数字:"); for(j=0;j<2;j=1) { scanf("%s",&k); getchar(); switch(k) { case '1':fun4();break; case '2': case '3': case '4': case '5':printf("\t\t\t\t系统即将退出!!!\n");break; default:printf("\t\t\t\t输入错误!!\n请重新输入:");continue; } } system("pause"); } int fun4()//添加联系人! { int t,n,a; char f='y'; ptgs p=head,q; FILE *V; if((V=fopen("D://information.dat","a+"))==NULL) { printf("\t\t\t\t文件无法打开!!!\n"); system("pause"); fun3(); } fprintf(V,"\n\t\t\t\t***************************通讯录列表******************************\n"); while(p->next)p=p->next;//修改上一个指针域,使其指向现在的节点! while(f!='n'&&f!='N') { q=(ptgs)malloc(sizeof(pgs));//malloc内存分配函数;内存大小为sizeof(pgs ). p->next=q; p=q; q->next=q; printf("\t\t\t\t姓名:"); scanf("%s",q->chat.name); printf("\n\t\t\t\t贯籍:"); scanf("%s",q->chat.guan); printf("\n\t\t\t\t电话号码1:"); scanf("%s",q->chat.number1); do { n=0; if(app(q->chat.number1)!=11)//判断号码是否为十一位电话号码 { n=1; printf("\t\t\t\t您输入的号码格式不正确!\n"); printf("\t\t\t\t请重新输入:"); scanf("%s",q->chat.number1); } else { for(t=0;t<11;t++) { if(q->chat.number1[t]<'0'||q->chat.number1[t]>'9')//判断号码是否都为0-9之间的字符 { n=1; printf("\t\t\t\t您输入的号码格式不正确!\n"); printf("\t\t\t\t请重新输入:"); scanf("%s",q->chat.number1); break; } } } }while(n); printf("\n\t\t\t\t电话号码2:"); scanf("%s",q->chat.number2); do { n=0; if(app(q->chat.number2)!=11) { n=1; printf("\t\t\t\t您输入的号码格式不正确!\n"); printf("\t\t\t\t请重新输入:"); scanf("%s",q->chat.number2); } else { for(t=0;t<11;t++) { if(q->chat.number2[t]<'0'||q->chat.number2[t]>'9') { n=1; printf("\t\t\t\t您输入的号码格式不正确!\n"); printf("\t\t\t\t请重新输入:"); scanf("%s",q->chat.number2); break; } } } }while(n); printf("\n\t\t\t\t邮箱:"); scanf("%s",p->chat.box); do { a=0; for(t=0;p->chat.box[t]='\0';t++) { if(p->chat.box[t]=='@') a++; } if(a!=1); { printf("\n\t\t\t\t输入的邮箱格式不合理!\n"); printf("\t\t\t\t请重新输入:"); scanf("%s",p->chat.box); } }while(a!=1); fprintf(V,"\t\t\t%s\t%s\t%s\t%s\t%s",p->chat.name,p->chat.guan,p->chat.number1,p->chat.number2,p->chat.box); p=p->next; printf("\n\t\t\t\t是否继续录入?(Y/N)!\n"); scanf("\t\t\t\t%c",&f); } fclose(V); system("pause"); fun3(); } int app(char *p) { int count,k; k=0; while((p[k] = getchar()) != '\n') { k++; } p='\0'; count=0; for(k=0;p[k]!='\0';k++) { count++; } return count; } ```
今年刚刚学的C语言,没有学过链表希望大佬可以帮忙写一下源代码,谢谢了
3、定义一个用于存储学生信息的结构体,结构体内包括学号(10位数字)、姓名(字符串)、英语及数学成绩(为结构体)、总成绩等信息。编写程序,实现使用链表输入若干学生的信息,并通过链表根据总成绩对学生信息进行排序,将排好序的学生信息在控制台进行显示并将相关信息存储到文件中。(55分)
关于c语言从文件中读取学生信息,处理并打印
![图片说明](https://img-ask.csdn.net/upload/201712/07/1512617928_774992.png) b) 建议函数流程: i. 打开数据文件,失败返回-1; ii. 从头到尾扫描数据文件(即预读一遍)获得学生人数; iii. 根据学生人数,利用malloc和sizeof等函数或运算符为struct student** pStudents分配内存; iv. 利用rewind函数,定位到文件头; v. 读取数据文件,并把每一条记录通过数组下标法或指针法保存到结构体数组pStudents中; vi. 关闭文件; vii. 返回学生人数。 c) 数据文件格式说明: 一行一条学生信息的记录,不同属性用空格隔开,输入数据中无总成绩记录,例如: 张三 通信 89 93 95 李四 网络 88 91 94 王五 物联网 71 94 88 3. 编写统计函数: a) 函数定义void Count(struct student pStudents[], int num)。输入参数分别为保存学生的结构体数组和学生人数。 b) 功能为:统计所有学生的总成绩和每个专业(假定一共三个专业:通信,网络,物联网)的平均成绩;输入参数包括学生信息结构体数组,学生人数,返回的每个学生的总成绩直接填充到对应的输入结构体数组对应字段中。统计信息包括三个专业的总人数、平均成绩数组,用全局变量来表示。访问每个学生信息的时候,用指针来指向当前正在处理的学生。 c) 设计一个或者三个带参数的宏,判断输入的字符串是否是指定的专业名称,并在函数Count中使用。 5. 编写main函数实现: a) 定义变量,其中保存学生信息的数据文件直接在源代码中初始化; b) 读取学生信息,如果失败,打印失败信息并退出程序; c) 统计学生信息; d) 输出统计信息。 e) 释放内存。 ``` #include <stdio.h> #include <stdlib.h> #include <string.h> struct student{ char name[15]; char major[15]; int Eng_sco; int cal_sco; int c_sco; int sum; }; int tx_per=0,tx_ave,tx_sum=0; int wl_per=0,wl_ave,wl_sum=0; int wlw_per=0,wlw_ave,wlw_sum=0; int ReadStudentInfo(const char* filename, struct student** pStudents); void Count(struct student pStudents[], int num); int main() { int count; int m; struct student *list; count=ReadStudentInfo("readme.txt", &list); printf("学生信息: \n"); printf("----------------------------------------------------\n"); printf("序号 姓 名 专业名称 英语成绩 线性代数成绩 c语言成绩 总成绩\n"); for(m=1;m<=count;m++) { printf("%4d %s %s %4d %4d %4d %4d\n",m,(list+m-1)->name,(list+m-1)->major,(list+m-1)->Eng_sco,(list+m-1)->cal_sco,(list+m-1)->c_sco,(list+m-1)->sum); } Count(list, count); printf("\n统计信息 :\n"); printf("----------------------------------------------------\n"); printf("序号 专业名称 学生人数 平均成绩\n"); printf(" 1 通信 %d %d\n",tx_per,tx_ave); printf(" 2 网络 %d %d\n",wl_per,wl_ave); printf(" 3 物联网 %d %d\n",wlw_per,wlw_ave); return 0; } int ReadStudentInfo(const char* filename, struct student** pStudents) { FILE *fp; char ch; int i=1,j; fp=fopen(readme.txt,"r"); if(fp==NULL) { printf("cann't open the file"); exit(-1); } ch=fgetc(fp); while(ch!=EOF) { if(ch=='\n') { i++; } ch=fgetc(fp); } rewind(fp); *pStudents=(struct student*)malloc(sizeof(** pStudents)*i); for(j=0;j<i;j++) { fread(&*pStudents[j],sizeof(struct student)-sizeof(int),1,fp); (*pStudents+j)->sum=((*pStudents+j)->Eng_sco+(*pStudents+j)->cal_sco+(*pStudents+j)->c_sco); } fclose(fp); return i; } void Count(struct student pStudents[], int num) { int n=1; for(n=1;n<=num;n++) { if(!strcmp((pStudents+n-1)->major,"通信")) { tx_per++; tx_sum=tx_sum+(pStudents+n-1)->sum; } if(!strcmp((pStudents+n-1)->major,"网络")) { wl_per++; wl_sum=wl_sum+(pStudents+n-1)->sum; } if(!strcmp((pStudents+n-1)->major,"物联网")) { wlw_per++; wlw_sum=wlw_sum+(pStudents+n-1)->sum; } tx_ave=tx_sum/tx_per; wl_ave=wl_sum/wl_per; wlw_ave=wlw_sum/wlw_per; } free(pStudents); } ``` 运行不起来,是哪里出问题了?
用C语言编写简单学生学籍管理系统。有一段已经定义好的函数,求大佬帮忙编写完整。在线急等。求各位大佬帮帮忙,重谢!!
``` #include <stdio.h> #include <string.h> #include <stdlib.h> #include <conio.h> typedef struct { int Id; //学号 char name[10]; //姓名 char sex[2]; //性别 int room; //宿舍号 int tel; //电话号码 } StudentInfo; //定义学生信息的结构体类型 typedef struct { int Id; char courseNo[10]; //课程编号 char courseName[20];//课程名 double a; // 课程学分 double b; // 平时成绩 double c; // 实验成绩 double d; // 卷面成绩 double e; // 综合成绩 double f; // 实际学分 } MarkInfo; //定义课程信息的结构体类型 void ReadFile(); //读取文件 void DisplayMainMenu(); //显示主菜单 void DataInput(); //数据录入 void DataQuery(); //数据查询 void DataDelete(); //数据删除 void DataSort(); //数据排序 void QueryById(int ); //按学号查询 void QueryByRoom(int ); //按宿舍查询 void QueryMark(int ); //按成绩查询 void sort1(); //按综合成绩排序 void sort2(); //按实得学分排序 void markput(); //成绩输出 StudentInfo si[30]; // 学生信息结构数组 MarkInfo mi[150]; // 学生成绩结构数组 int sp=0; // 学生信息结构数组中学生数 int mp=0; // 学生成绩结构数组中成绩数 void ReadFile( )//读取文件 { FILE *fp; if((fp = fopen("A.txt","r"))==NULL) printf("cant open the file\n"); while (!feof(fp)) { fscanf(fp,"%d%s%s%d%d",&si[sp].Id,si[sp].name,&si[sp].sex,&si[sp].room,&si[sp].tel); sp++; } fclose (fp); fp = fopen("B.txt","r"); while (!feof(fp)) { fscanf(fp,"%d%s%s%d%d%d%d",&mi[mp].Id,mi[mp].courseNo,mi[mp].courseName,&mi[mp].a,&mi[mp].b,&mi[mp].c, &mi[mp].d); if (mi[mp].c == -1) mi[mp].e = 0.3*(mi[mp].b/1.0)+0.7*(mi[mp].d/1.0); else mi[mp].e = 0.15*(mi[mp].b/1.0)+0.15*(mi[mp].c/1.0)+0.7*(mi[mp].d/1.0); if(mi[mp].e >= 90. ) mi[mp].f = mi[mp].a; else if ( mi [mp].e >= 80. ) mi[mp].f = mi[mp].a *0.8; else if ( mi[mp].e >= 70. ) mi[mp].f = mi[mp].a *0.75; else if ( mi[mp].e >= 60. ) mi[mp].f = mi[mp].a *0.6; else mi[mp].f = 0; mp++; } fclose(fp); } void DisplayMainMenu() //显示主菜单 { printf ("\n 1) 数据录入 \n 2) 数据查询 \n 3) 数据删除 \n 4) 数据排序 \n 5) 程序结束\n "); } void DataInput()//数据查询 { FILE *fp; int i; printf ("学生的学号 课程编号 课程名称 学分 平时成绩 实验成绩 卷面成绩\n"); while(1) { scanf("%d%s%s%d%d%d%d",&mi[mp].Id,mi[mp].courseNo,mi[mp].courseName,&mi[mp].a,&mi[mp].b,&mi[mp].c, &mi[mp].d); if(mi[mp].Id==-1) break; if (mi[mp].c == -1) mi[mp].e = 0.3*mi[mp].b+0.7*mi[mp].d; else mi[mp].e = 0.15*mi[mp].b+0.15*mi[mp].c+0.7*mi[mp].d; if ( mi[mp].e >= 90. ) mi[mp].f = mi[mp].a; else if ( mi [mp].e >= 80. ) mi[mp].f = mi[mp].a *0.8; else if ( mi[mp].e >= 70. ) mi[mp].f = mi[mp].a *0.75; else if ( mi[mp].e >= 60. ) mi[mp].f = mi[mp].a *0.6; else mi[mp].f = 0; mp++; } fp = fopen("B.txt","r+"); for(i=0;i<mp;i++) { fprintf(fp,"%d%s%s%d%d%d%d",&mi[i].Id,mi[i].courseNo,mi[i].courseName,&mi[i].a,&mi[mp].b,&mi[i].c, &mi[i].d); fclose(fp); } } void DataQuery()//数据查询 { int x,y,z; printf("\n 1) 学生基本情况查询\n 2) 成绩查询\n");//--------------------------选择查询内容 scanf("%d",&x); if (x == 1) // 查询学生信息 { printf ("1) 按学号查询 2) 按宿舍查询\n");//-------------------------------选择查询方式 scanf("%d",&y); if (y == 1 ) { printf ("输入学号\n");//-----------------------------------------------按学生学号查询 scanf ("%d",&z); QueryById(z); } if (y == 2) { } if ( x ==2) // 查询成绩信息---------------------------------------查询学生成绩(输入学号) { printf ("输入学号\n"); scanf ("%d",&y); QueryMark(y); } } } void DataDelete()//数据删除 { FILE *fp; int x; int i=0; int k,d; printf( "输入学号\n"); scanf( "%d",&x); while( si[i].Id != x) i++; if (i<sp-1) { for ( k=i; k<sp-1; k++) { si[k] = si[k+1]; } } if ( i<sp) sp--; d = 0; for (k=0;k<mp;k++) { if ( mi[k].Id == x ) d++; else mi[k-d] = mi[k]; } mp = mp - d; fp = fopen("D:B.txt","r+"); for(i=0;i<mp;i++) fprintf(fp,"%d%s%s%d%d%d%d",&mi[i].Id,mi[i].courseNo,mi[i].courseName,&mi[i].a,&mi[i].b,&mi[i].c, &mi[i].d); } void sort1() { int i,j; MarkInfo t; for (i=mp-1;i>=1;i--) { for (j=0;j<i;j++) { if (mi[j].e>mi[j+1].e) { t=mi[j]; mi[j] = mi[j+1]; mi[j+1] = t; } } } markput(); } ``` 这段函数是定义好的,求大佬帮帮忙编写完! 要求:使用下面的数据,用C语言设计一个简单的学籍管理系统,实现出最基本的功能。 学生基本信息文件(A.TXT)及其内容:A.TXT文件不需要编程录入数据,可用文本编辑工具直接生成: 学号 姓名 性别 宿舍号码 电话号码 01 张成成 男 501 87732111 02 李成华 女 101 87723112 03 王成凤 女 101 87723112 04 张明明 男 502 87734333 05 陈东 男 501 87732111 06 李果 男 502 87734333 07 张园园 女 102 87756122 … …. .. … ……….. 学生成绩基本信息文件(B.TXT)及其内容: 学号 课程编号 课程名称 学分 平时成绩 实验成绩 卷面成绩 综合成绩 实得学分 01 A01 大学物理 3 66 78 82 02 B03 高等数学 4 78 -1 90 01 B03 高等数学 4 45 -1 88 02 C01 VF 3 65 76 66 … …. ………. .. .. … (一) 功能要求及说明: (1) 数据录入功能: 对B.TXT进行数据录入,只录入每个学生的学号、课程编号、课程名称、学分、平时成绩、实验成绩、卷面成绩共7个数据. 综合成绩、学分由程序根据条件自动运算。 综合成绩的计算:如果本课程的实验成绩为-1,则表示无实验,综合成绩=平时成绩*30%+卷面成绩*70%; 如果实验成绩不为-1,表示本课程有实验,综合成绩=平时成绩*15%+实验成绩*.15%+卷面成绩*70% . 实得学分的计算: 采用等级学分制. 综合成绩在90-100之间 ,应得学分=学分*100% 综合成绩在80-90之间 ,应得学分=学分*80% 综合成绩在70-80之间 ,应得学分=学分*75% 综合成绩在60-70之间 ,应得学分=学分*60% 综合成绩在60以下 ,应得学分=学分*0% (2)查询功能:分为学生基本情况查询和成绩查询两种 A:学生基本情况查询: A1----输入一个学号或姓名(可实现选择),查出此生的基本信息并显示输出。 A2---输入一个宿舍号码,可查询出本室所有的学生的基本信息并显示输出。 B:成绩查询: B1:输入一个学号时,查询出此生的所有课程情况,格式如下: 学 号:xx 姓 名:xxxxx 课程编号:xxx 课程名称:xxxxx 综合成绩:xxxx 实得学分: xx 课程编号:xxx 课程名称:xxxxx 综合成绩:xxxx 实得学分: xx 课程编号:xxx 课程名称:xxxxx 综合成绩:xxxx 实得学分: xx … … … … ……… … … 共修:xx科,实得总学分为: xxx (3)删除功能:当在A.TXT中删除一个学生时,自动地在B.TXT中删除此人所有信息。 (4 ) 排序功能:能实现选择按综合成绩或实得学分升序或降序排序并显示数据。
动态规划入门到熟悉,看不懂来打我啊
持续更新。。。。。。 2.1斐波那契系列问题 2.2矩阵系列问题 2.3跳跃系列问题 3.1 01背包 3.2 完全背包 3.3多重背包 3.4 一些变形选讲 2.1斐波那契系列问题 在数学上,斐波纳契数列以如下被以递归的方法定义:F(0)=0,F(1)=1, F(n)=F(n-1)+F(n-2)(n&gt;=2,n∈N*)根据定义,前十项为1, 1, 2, 3...
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过...
为啥国人偏爱Mybatis,而老外喜欢Hibernate/JPA呢?
关于SQL和ORM的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行了一番讨论,感触还是有一些,于是就有了今天这篇文。 声明:本文不会下关于Mybatis和JPA两个持久层框架哪个更好这样的结论。只是摆事实,讲道理,所以,请各位看官勿喷。 一、事件起因 关于Mybatis和JPA孰优孰劣的问题,争论已经很多年了。一直也没有结论,毕竟每个人的喜好和习惯是大不相同的。我也看...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
知乎高赞:文中列举了互联网一线大厂程序员都在用的工具集合,涉及面非常广,小白和老手都可以进来看看,或许有新收获。
【超详细分析】关于三次握手与四次挥手面试官想考我们什么?
在面试中,三次握手和四次挥手可以说是问的最频繁的一个知识点了,我相信大家也都看过很多关于三次握手与四次挥手的文章,今天的这篇文章,重点是围绕着面试,我们应该掌握哪些比较重要的点,哪些是比较被面试官给问到的,我觉得如果你能把我下面列举的一些点都记住、理解,我想就差不多了。 三次握手 当面试官问你为什么需要有三次握手、三次握手的作用、讲讲三次三次握手的时候,我想很多人会这样回答: 首先很多人会先讲下握...
压测学习总结(1)——高并发性能指标:QPS、TPS、RT、吞吐量详解
一、QPS,每秒查询 QPS:Queries Per Second意思是“每秒查询率”,是一台服务器每秒能够相应的查询次数,是对一个特定的查询服务器在规定时间内所处理流量多少的衡量标准。互联网中,作为域名系统服务器的机器的性能经常用每秒查询率来衡量。 二、TPS,每秒事务 TPS:是TransactionsPerSecond的缩写,也就是事务数/秒。它是软件测试结果的测量单位。一个事务是指一...
新程序员七宗罪
当我发表这篇文章《为什么每个工程师都应该开始考虑开发中的分析和编程技能呢?》时,我从未想到它会对读者产生如此积极的影响。那些想要开始探索编程和数据科学领域的人向我寻求建议;还有一些人问我下一篇文章的发布日期;还有许多人询问如何顺利过渡到这个职业。我非常鼓励大家继续分享我在这个旅程的经验,学习,成功和失败,以帮助尽可能多的人过渡到一个充满无数好处和机会的职业生涯。亲爱的读者,谢谢你。 -罗伯特。 ...
活到老,学到老,程序员也该如此
全文共2763字,预计学习时长8分钟 图片来源:Pixabay 此前,“网传阿里巴巴要求尽快实现P8全员35周岁以内”的消息闹得沸沸扬扬。虽然很快被阿里辟谣,但苍蝇不叮无缝的蛋,无蜜不招彩蝶蜂。消息从何而来?真相究竟怎样?我们无从而知。我们只知道一个事实:不知从何时开始,程序猿也被划在了“吃青春饭”行业之列。 饱受“996ICU”摧残后,好不容易“头秃了变强了”,即将步入为“高...
Vue快速实现通用表单验证
本文开篇第一句话,想引用鲁迅先生《祝福》里的一句话,那便是:“我真傻,真的,我单单知道后端整天都是CRUD,我没想到前端整天都是Form表单”。这句话要从哪里说起呢?大概要从最近半个月的“全栈工程师”说起。项目上需要做一个城市配载的功能,顾名思义,就是通过框选和拖拽的方式在地图上完成配载。博主选择了前后端分离的方式,在这个过程中发现:首先,只要有依赖jQuery的组件,譬如Kendoui,即使使用...
2019年Spring Boot面试都问了什么?快看看这22道面试题!
Spring Boot 面试题 1、什么是 Spring Boot? 2、Spring Boot 有哪些优点? 3、什么是 JavaConfig? 4、如何重新加载 Spring Boot 上的更改,而无需重新启动服务器? 5、Spring Boot 中的监视器是什么? 6、如何在 Spring Boot 中禁用 Actuator 端点安全性? 7、如何在自定义端口上运行 Sprin...
Java 数据持久化系列之JDBC
前段时间小冰在工作中遇到了一系列关于数据持久化的问题,在排查问题时发现自己对 Java 后端的数据持久化框架的原理都不太了解,只有不断试错,因此走了很多弯路。于是下定决心,集中精力学习了持久化相关框架的原理和实现,总结出这个系列。 上图是我根据相关源码和网上资料总结的有关 Java 数据持久化的架构图(只代表本人想法,如有问题,欢迎留言指出)。最下层就是今天要讲的 JDBC,上一层是数据库连接池...
高性能分布式缓存的设计原理
又是一个没有开工红包的公司!!! 问题分析 通过以上对话,各位是否能够猜到所有缓存穿透的原因呢?回答之前我们先来看一下缓存策略的具体代码 缓存服务器IP=hash(key)%服务器数量 这里还要多说一句,key的取值可以根据具体业务具体设计。比如,我想要做负载均衡,key可以为调用方的服务器IP;获取用户信息,key可以为用户ID;等等。 在服务器数量不变的情况下,以上设计没有问题。但是...
带你涨姿势的认识一下 Kafka 消费者
之前我们介绍过了 Kafka 整体架构,Kafka 生产者,Kafka 生产的消息最终流向哪里呢?当然是需要消费了,要不只产生一系列数据没有任何作用啊,如果把 Kafka 比作餐厅的话,那么生产者就是厨师的角色,消费者就是客人,只有厨师的话,那么炒出来的菜没有人吃也没有意义,如果只有客人没有厨师的话,谁会去这个店吃饭呢?!所以如果你看完前面的文章意犹未尽的话,可以继续让你爽一爽。如果你没看过前面的...
小白学 Python 爬虫(5):前置准备(四)数据库基础
人生苦短,我用 Python 前文传送门: 小白学 Python 爬虫(1):开篇 小白学 Python 爬虫(2):前置准备(一)基本类库的安装 小白学 Python 爬虫(3):前置准备(二)Linux基础入门 小白学 Python 爬虫(4):前置准备(三)Docker基础入门 本篇文章,我们接着介绍基础内容,数据库。 爬虫将数据爬取完成后,总要有地方存放吧,这个数据存在哪里呢? ...
阿里P8数据架构师:顶级开发者都在用什么数据库?
其实从去年已经隐隐约约感觉到数据库的有变化,只是没有想到变得这么快。今年的一些事情实实在在地给了某些数据库重击,如果以前去某数据库还是喊喊,然后该用还用,今年从传统领域刮起的去某数据库的风,已经开始了,并且后面的乌云密布也看得见。 最近看一篇国外的开源产品提供厂商的一篇文字,主要是在询问了他的几百位客户后得出了下图中的2019年数据库的使用趋势。 从图中可以看出,MySQL以38.9...
面试官:关于Java性能优化,你有什么技巧
通过使用一些辅助性工具来找到程序中的瓶颈,然后就可以对瓶颈部分的代码进行优化。 一般有两种方案:即优化代码或更改设计方法。我们一般会选择后者,因为不去调用以下代码要比调用一些优化的代码更能提高程序的性能。而一个设计良好的程序能够精简代码,从而提高性能。 下面将提供一些在JAVA程序的设计和编码中,为了能够提高JAVA程序的性能,而经常采用的一些方法和技巧。 1.对象的生成和大小的调整。 J...
互联网公司分布式系统架构演进之路
介绍 分布式和集群的概念经常被搞混,现在一句话让你明白两者的区别。 分布式:一个业务拆分成多个子业务,部署在不同的服务器上 集群:同一个业务,部署在多个服务器上 例如:电商系统可以拆分成商品,订单,用户等子系统。这就是分布式,而为了应对并发,同时部署好几个用户系统,这就是集群 1 单应用架构 2 应用服务器和数据库服务器分离 单机负载越来越来,所以要将应用服务器和数据库服务器分离 3 应用服务...
为什么你的高效交付,却没有好的业务成果?
作者| 彭鑫(公亮) 出品|阿里巴巴新零售淘系技术部 11月中旬,作者在 TOP 100 案例和人人都是产品经理的两次大会上分别进行了两场关于价值交付的分享,结合分享后的反馈焦点,立足业务整体交付的价值最大化,特产此文。 持续需求交付的痛点 ▶没有价值的交付等于没有交付 随着敏捷方法的普及,越来越多的团队引入了敏捷以推动业务的快速迭代、小步快跑、及时的响应市场变化。在各种敏捷框架...
快速搭建 SpringCloud 微服务开发环境的脚手架
本文适合有 SpringBoot 和 SpringCloud 基础知识的人群,跟着本文可使用和快速搭建 SpringCloud 项目。本文作者:HelloGitHub-秦...
JavaScript 中, 5 种增加代码可读性的最佳实践
作者:Milos Protic 译者:前端小智 来源:blog.risingstack 为了保证的可读性,本文采用意译而非直译。 简介 如果咱们关注代码本身结构及可读笥,而不是只关心它是否能工作,那么咱们写代码是有一定的水准。专业开发人员将为未来的自己和“其他人”编写代码,而不仅仅只编写能应付当前工作的代码。 在此基础上,可读性高的代码可以定义为自解释的、易于人理解的、易于更改...
Java 9 ← 2017,2019 → Java 13 ,来看看Java两年来的变化
距离 2019 年结束,只剩下 10 几天了。你做好准备迎接 2020 年了吗? 一到年底,人就特别容易陷入回忆和比较之中,比如说这几天, 的对比挑战就火了! 这个话题登上了微博的热搜榜,也刷爆了朋友圈,人们纷纷晒出自己2017和2019的照片对比。 作为一个技术宅,我也做了一个对比: 2017 年 9 月 21 日,Java 9 正式发布,并且在2017年8月,JCP执行委员会提出将J...
【图解算法面试】记一次面试:说说游戏中的敏感词过滤是如何实现的?
版权声明:本文为苦逼的码农原创。未经同意禁止任何形式转载,特别是那些复制粘贴到别的平台的,否则,必定追究。欢迎大家多多转发,谢谢。 小秋今天去面试了,面试官问了一个与敏感词过滤算法相关的问题,然而小秋对敏感词过滤算法一点也没听说过。于是,有了下下事情的发生… 面试官开怼 面试官:玩过王者荣耀吧?了解过敏感词过滤吗?,例如在游戏里,如果我们发送“你在干嘛?麻痹演员啊你?”,由于“麻痹”是一个敏感词,...
程序员需要了解的硬核知识之汇编语言(一)
之前的系列文章从 CPU 和内存方面简单介绍了一下汇编语言,但是还没有系统的了解一下汇编语言,汇编语言作为第二代计算机语言,会用一些容易理解和记忆的字母,单词来代替一个特定的指令,作为高级编程语言的基础,有必要系统的了解一下汇编语言,那么本篇文章希望大家跟我一起来了解一下汇编语言。 汇编语言和本地代码 我们在之前的文章中探讨过,计算机 CPU 只能运行本地代码(机器语言)程序,用 C 语言等高级语...
OpenCV-Python 绘图功能 | 七
目标 学习使用OpenCV绘制不同的几何形状 您将学习以下功能:cv.line(),cv.circle(),cv.rectangle(),cv.ellipse(),cv.putText()等。 代码 在上述所有功能中,您将看到一些常见的参数,如下所示: img:您要绘制形状的图像 color:形状的颜色。对于BGR,将其作为元组传递,例如:(255,0,0)对于蓝色。对于灰度,只需传递...
GitHub 标星 1.6w+,我发现了一个宝藏项目,作为编程新手有福了!
大家好,我是 Rocky0429,一个最近老在 GitHub 上闲逛的蒟蒻… 特别惭愧的是,虽然我很早就知道 GitHub,但是学会逛 GitHub 的时间特别晚。当时一方面是因为菜,看着这种全是英文的东西难受,不知道该怎么去玩,另一方面是一直在搞 ACM,没有做一些工程类的项目,所以想当然的以为和 GitHub 也没什么关系(当然这种想法是错误的)。 后来自己花了一个星期看完了 Pyt...
Java知识体系最强总结(2020版)
更新于2019-12-15 10:38:00 本人从事Java开发已多年,平时有记录问题解决方案和总结知识点的习惯,整理了一些有关Java的知识体系,这不是最终版,会不定期的更新。也算是记录自己在从事编程工作的成长足迹,通过博客可以促进博主与阅读者的共同进步,结交更多志同道合的朋友。特此分享给大家,本人见识有限,写的博客难免有错误或者疏忽的地方,还望各位大佬指点,在此表示感激不尽。 文章目录...
计算机专业的书普遍都这么贵,你们都是怎么获取资源的?
介绍几个可以下载编程电子书籍的网站。 1.Github Github上编程书资源很多,你可以根据类型和语言去搜索。推荐几个热门的: free-programming-books-zh_CN:58K 星的GitHub,编程语言、WEB、函数、大数据、操作系统、在线课程、数据库相关书籍应有尽有,共有几百本。 Go语言高级编程:涵盖CGO,Go汇编语言,RPC实现,Protobuf插件实现,Web框架实...
毕业5年,我问遍了身边的大佬,总结了他们的学习方法
我问了身边10个大佬,总结了他们的学习方法,原来成功都是有迹可循的。
相关热词 c#怎么获得线程名 c# usb 采集器 c# csv 读取 c# sort() c# 关闭io流 c# 响应函数 插入 c#面对对象的三大特性 c# 打印 等比缩放 c#弹出右键菜单 c#1如何搞成01
立即提问