c语言课程设计:统计工资

2.1 设计题目
本课程设计要求设计一个公司职员的数据结构,并使用结构指针数组存储职员信息,统计公司员工工资总额和平均工资。
2.2 设计要求
设计要求实现如下功能:
(1)使用结构指针数组设计一个公司职员的数据结构,使用下述的结构定义:
typedef struct employee{
int age;
char *name;
double salary;
}*PEMP;
(2)在主函数里构造一个指针数组company,用来存放职工信息。
(3)设计一个update函数,用来给company赋值。
函数update(company, id, age, name, salary)的四个参数为:
company: 结构指针数组
id: company的下标
age: 年龄,整数类型
salary: 薪水,实数
(4)设计一个readin函数,直接采用调用update函数的方式进行赋值。例如:update(company, 2, 30, “LI MING”, 3000.0);
(5)编写total函数对工资求和。
这个函数应该能对全体职工和某一年龄段的职工的工资求和。
(6)编写mean函数求平均工资。
这个函数应该能对全体职工和大于某一年龄段的职工的工资求和并计算相应的平均值。

2.3 算法分析
为了简单起见,假设在主函数main中定义结构数组指针如下:
PEMP company[num];
下面说明几个函数的设计问题:
(1)readin函数
数组company属于main函数,它是不可见的,所以必须作为readin函数的参数。因为参数传递是传地址的方式,所以不需要返回值。以数据为例,这个函数的定义和使用方法如下:
void reading(company)
PEMP company[];
{
update(company, 2, 23, “张文”,3000.0);
update(company, 1, 33, “王微”,2400.0);
update(company, 2, 23, “李小”,3055.0);
}
(2)total函数
它也必须以数组company作为参数,而且要返回工资总额。可将它的原型设计为:
double total (PEMP *);
total函数应该允许输入年龄范围,如果年龄不合理,应该允许重新输入。对输入数据进行判别,确保无误再进行计算。
for( ; ; )
{
printf(“输入年龄范围”);
scanf(“%d%d”,&age1, &age2)
if(age1>age2)
{
i=age1;
age1=age2;
age2=i;
}
if((age1>=0)&&(age2<=100)&&(age2>=0)&&(age2<=100)&&(age2>age1))
break;
}
(3)mean函数
mean函数也必须以数组company作为参数,而且要返回平均工资。将它的函数原型设计为:
double mean (PEMP *);
mean函数应该允许输入年龄范围。对输入字符进行判别,确保无误再进行计算,注意允许大小写。
printf(“求某一年龄段以上的职工的平均工资\n”);
printf(“默认是全体职工的平均工资,要改变计算方式请输入Y/y\n”);
getchar();
ch=getchar();
if(ch==’Y’||ch=’y’)
{
printf(“age:”);
scanf(“%d”,&age);
}
(4)申请内存
在update函数中,需要申请内存空间。
PEMP emp
If((emp=(PEMP) malloc (sizeof(struct employee)))==NULL)return;
注意emp是指针,所以要使用sizeof(struct employee)。

1个回答

条件都给你了,自己写呗!

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
c语言课程设计:学生档案管理系统

要求有5个功能。1 输入功能:录入学生信息; 2 显示功能:完成学生记录的显示; 3 查找功能:完成查看所有学生,按学号或姓名查找学生的相关记录,并显示; 4 更新功能:(增加或删除)。 利用结构体数组实现学生信息的数据结构设计,且各个功能模块用函数的形式实现。(加注释的话更好)

c语言课程设计:学生信息管理系统,求指导啊

(1)系统以菜单方式工作,问题描述 学生信息包括:学号,姓名,年龄,性别,出生年月,地址,电话,E-mail等。试设计一学生信息管理系统,使之能提供以下功能: 学生信息录入功能(学生信息用文件保存)---输入 学生信息浏览功能——输出 查询、排序功能——算法 按学号查询 按姓名查询 学生信息的删除与修改(可选项) (2)功能要求,界面简单明了;有一定的容错能力,比如输入的成绩不在0~100之间,就提示不合法,要求重新输入; 学生信息管理 1. 输入学生信息 2. 输出学生信息 3. 按姓名查询 4. 按学号查询 5. 按姓名排序 6. 按学号排序 7.删除指定学号学生信息 8.修改指定学号学生信息 0. 退出 请选择菜单:

c语言课程设计——数据统计程序

希望哪位大佬帮忙解答一下,谢谢![图片](https://img-ask.csdn.net/upload/201706/09/1497017750_796336.png)

C语言编程题:统计正整数[M,N]之间含有2个位上的数字为6的所有整数个数,且M<N。

编程实现:统计正整数[M,N]之间含有2个位上的数字为6的所有整数个数,且M<N。 示例: 输入格式:100 1000 输出格式:26

C语言 编写程序:输入6名学生5门课程的成绩,分别统计出每个学生5门课程的平均成绩。

C语言 编写程序:输入6名学生5门课程的成绩,分别统计出每个学生5门课程的平均成绩。

C语言程序设计:解一元二次方程

如何编写一个解一元二次方程的C语言程序。要能求出x1,x2,还要有无解的情况。

C语言课程设计物业费管理系统

新户信息的添加。(户主姓名、性别、身份证号、联系电话、楼号、单元号、房号、平米数、每平米物业价格、应缴纳物业费,备注信息) 修改住户信息的功能 删除住户信息的功能 应缴物业费自动生成。每月1号,自动生成本月份的物业费。如果该住户之前的物业费未交清,则本月物业费与之前拖欠费用进行累加,为该用户应缴纳的物业费 缴费功能。根据用户缴纳金额,修改“应缴纳物业费” 能够按楼号 分类统计所有未交清物业费的记录 能够按拖欠款项多少,对所有用户信息进行从大到小排序 用菜单进行管理

c语言课程设计分油问题

输入三个油瓶容量与目标容量, 用邻接矩阵求它的最短路径 ,先判断两点间有没有路 最短路是什么, 调用邻接矩阵函数求 。

大一c语言的课程设计题目 有点小复杂 急急!

1. 学生成绩管理系统基本要求: 假设有1个班45人的成绩放在1个数组中。系统要求以随机函数生成学生成绩。系统能按照要求根据不同条件对学生成绩进行管理。 2. 系统模块及操作要求: (1) 编写一个成绩生成函数。使用随机数方法,利用随机函数生成学生的各门课程的成绩(每门课程的成绩都是0-100之间的整数),通过调用该函数生成全部学生的成绩。 (2) 先采用冒泡排序法,将学生成绩从高到低进行排序,再输入一个学生的成绩,将此成绩按照排序规律插入已排好序的学生成绩数组,最后将排好序的成绩单进行反序存放。 (3) 在函数中进行全班学生成绩从高到低排名, 排名方式根据函数的style参数进行,如style为‘a'按升序排序,style为 ' d ' 按降序排序。 (4) 用指针优化学生成绩排名。用指针实现数组的输入输出以及数组的排序(在函数中进行)。采用指针方法,输入字符串“ student score ”, 不使用 strcpy() 函数,自行编制函数实现复制该字符串并在第四步输出排序后的成绩单后下一行输出该字符串。 (5) 定义一个结构体数组,存放全班学生的学号,姓名,三门课的成绩,输出单门课成绩最高的学生的学号、姓名、以及该门课程的成绩,输出三门课程的平均分数最高的学生的学号、姓名及其平均分,再将全班学生按照平均分数从高到低用选择法进行排序,输出结果。 (6) 学生成绩文件管理。将全班学生的相关数据,存入文件中,再从文件中读出按照平均分数从高到低进行排序,分别将结果输出到屏幕上和另一文件中,再从文件中读取第 2 , 4 , 6 , 8 , 10 个学生的数据显示。![图片说明](https://img-ask.csdn.net/upload/201605/31/1464670799_705905.jpg)

C语言课程设计---商品订购系统 调试

#include <stdio.h> #include <string.h> int inumber = 0; //商品量的统计 int ibuy = 0; //订单的统计 void secondmain(); //管理维护子菜单 void jianpanload(); //输入商品 void scanproduct(); //浏览商品 void searchproduct(); //搜索商品 void dinggou(); //订购商品 void lookdinggou(); //查询订单 void addproduct(); //增加商品 void deleteproduct(); //删除商品 void saveproduct(); //保存商品 void savedinggou(); //保存订单 void wenbenload(); //从文本导入商品 struct product { char name[30]; //商品名 int number; //货号 char vender[30]; //厂家 char filed[100]; //产地 int stock; //存量 double price; //单价 }; struct product a[100]; struct dinggou { int bgname; //货号 int bmany; //订购量 int btime; //日期时间 char bname[100]; //客户名 char baddress[100]; //客户地址 int bnumber; //客户号 }; struct dinggou b[100]; int main(void) { int i; wenbenload(); do { printf("\n\n\n\n\n\n"); printf("**************************欢迎使用商品订购系统v1.0******************************\n"); printf(" ┏━━━━━━━━━━━━━━━━━━━┓\n"); printf(" ┃ 1.浏览商品信息 ┃\n"); printf(" ┃ 2.订购商品 ┃\n"); printf(" ┃ 3.订单查询 ┃\n"); printf(" ┃ 4.搜索商品 ┃\n"); printf(" ┃ 5.管理菜单 ┃\n"); printf(" ┃ 0.退出系统 ┃\n"); printf(" ┗━━━━━━━━━━━━━━━━━━━┛\n"); printf("********************************************************************************\n"); printf("\n\n\t\t请输入你的操作(0~5): "); scanf("%d",&i); switch(i) { case 1: scanproduct(); break; case 2: dinggou(); break; case 3: lookdinggou(); break; case 4: searchproduct(); break; case 5: secondmain(); break; case 0: //退出系统的界面 printf("\n\n\n\n\n\n\n\n"); printf("\n\n\t\t\t欢迎使用本系统\n\n\n\n\n\t\t\t欢迎再次使用\n"); } }while(1); return 0; } //浏览商品 void scanproduct() { int i; printf("\t\t\t\t\t商品信息列表\n"); for (i = 0; i < inumber; i++) { printf("名称 : %s\n",a[i].name); printf("货号 : %d\n",a[i].number); printf("厂家 : %s\n",a[i].vender); printf("产地 : %s\n",a[i].filed); printf("存量 : %d\n",a[i].stock); printf("单价 : %.2lf\n\n\n",a[i].price); } printf("\n\n\n\n\n\n\t\t\t"); printf("返回主菜单\n"); printf("\t\t\t"); //每个/t占8个字节,可理解为空格键 return; } //商品的订购 void dinggou() { char ch; int i, j, t, c = 1; int n = 1; int m = 0; do { switch(n) { case 1: printf("\t\t\t\t商品信息列表\n"); //显示商品的名称、货号信息,以便于订购 printf("名称\t 货号\t 库存\n"); for (i = 0; i < inumber; i++) { printf("%s\t %d\t %d\n\n\n",a[i].name,a[i].number,a[i].stock); } printf("\n\n\n"); printf("\t\t\t\t商品订单\n"); printf("\n\t\t\t请输入你的第%d个订单信息:\n",m + 1); printf("\n\t\t\t货号:"); fflush(stdin); scanf("%d",&b[ibuy].bgname); //检测是否含有此商品 j = 1; for (i = 0; i < inumber; i++) { if(a[i].number == b[ibuy].bgname) { j = 0; t = i; } } //若有商品继续购买项目 if(j == 0) { printf("\n\t\t\t订购量:"); fflush(stdin); scanf("%d",&b[ibuy].bmany); if (a[t].stock >= b[ibuy].bmany) { a[t].stock = a[t].stock - b[ibuy].bmany; //顾客购买后商品的库存计算 printf("\n\t\t\t日期时间:"); fflush(stdin); scanf("%d",&b[ibuy].btime); printf("\n\t\t\t客户名:"); fflush(stdin); gets(b[ibuy].bname); printf("\n\t\t\t客户地址:"); fflush(stdin); gets(b[ibuy].baddress); printf("\n\t\t\t客户号:"); printf("%d\n",b[ibuy].bnumber); ibuy++; m++; printf("\n\n\n\t\t\t\t"); } else { printf("\n\n\t\t\t订购数目超出库存\n"); printf("\t\t\t"); } } //若没有商品的提示及操作 else { printf("\n\n\t\t\t查无此货\n"); printf("\t\t\t"); } case 2: printf("是否继续输入订购?(Y/N)"); fflush(stdin); scanf("%c",&ch); if(ch == 'N' || ch == 'n') { c = 0; break; } else if(ch == 'Y' || ch == 'y') { c = 0; n = 1; break; } else if(ch != 'n' || ch != 'N' || ch != 'Y' || ch != 'y') { n = 0; c = 1; break; } case 0: if(c == 1) { n = 2; } } }while(ch != 'n' && ch != 'N'); return ; } //订单的查询 void lookdinggou() { int i; printf("\t\t\t\t\t订单列表\n"); for (i = 0; i < ibuy; i++) { printf("货号 : %d\n",b[i].bgname); printf("订购量 : %d\n",b[i].bmany); printf("日期时间 : %d\n",b[i].btime); printf("客户名 : %s\n",b[i].bname); printf("客户地址 : %s\n",b[i].baddress); printf("客户号 : %d\n\n\n",b[i].bnumber); } printf("\n\n\n\n\n\n\t\t\t"); printf("返回主菜单\n"); printf("\t\t\t"); return; } //增加商品 void addproduct() { char ch; int i=1; int n = 1; do { switch(n) { case 1: printf("\t\t\t\t商品信息的增加\n"); printf("\t\t\t\t\t注:要重新输入已有及增加的商品\n"); printf("\n\t\t\t请输入你的第%d件商品的信息:\n",i); printf("\n\t\t\t名称:"); fflush(stdin); scanf("%s",a[inumber].name); printf("\n\t\t\t货号:"); fflush(stdin); scanf("%d",&a[inumber].number); printf("\n\t\t\t厂家:"); fflush(stdin); scanf("%s",a[inumber].vender); printf("\n\t\t\t产地:"); fflush(stdin); scanf("%s",a[inumber].filed); printf("\n\t\t\t存量:"); fflush(stdin); scanf("%d",&a[inumber].stock); printf("\n\t\t\t单价:"); fflush(stdin); scanf("%lf",&a[inumber].price); i++; inumber++; case 2: printf("是否继续输入记录?(Y/N)"); fflush(stdin); scanf("%c",&ch); if(ch == 'N' || ch ==' Y'|| ch == 'n'|| ch == 'y') { break; } if(ch ==' Y'|| ch == 'y') { n = 1; break; } case 0: printf("是否继续输入记录?(Y/N)"); fflush(stdin); scanf("%c",&ch); n = 2; } }while(ch != 'n' && ch != 'N'); return; } //删除商品 void deleteproduct() { int i; int j; char ch; int n = 1; do { switch(n) { case 1: printf("\t\t\t\t商品列表\n"); //显示商品的名称、货号信息,以便于下部的删除 for (i = 0; i < inumber; i++) { printf("名称 : %s\n",a[i].name); printf("ID : %d\n",i); printf("库存 : %d\n\n\n",a[i].stock); } //商品的搜索 printf("\n\n\n\t\t\t\t请输入你要删除商品的ID:"); scanf("%d",&j); i = j; while(i < inumber - 1) { strcpy(a[i].name, a[i + 1].name); a[i].number = a[i + 1].number; strcpy(a[i].filed, a[i + 1].filed); a[i].stock = a[i + 1].stock; a[i].price = a[i + 1].price; strcpy(a[i].vender, a[i + 1].vender); i++; } inumber--; case 2: printf("是否继续删除商品?(Y/N)"); fflush(stdin); scanf("%c",&ch); if(ch == 'N' || ch ==' Y'|| ch == 'n'|| ch == 'y') { break; } if(ch ==' Y'|| ch == 'y') { n = 1; break; } case 0: printf("是否继续输入记录?(Y/N)"); fflush(stdin); scanf("%c",&ch); n = 2; } }while(ch != 'n' && ch != 'N'); printf("\n\n\n\n\n\n\t\t\t"); printf("返回附加功能菜单\n"); printf("\t\t\t"); return; } //商品信息的保存 void saveproduct() { FILE *fpgoods; int i; fpgoods = fopen("goodsinfo.out","w"); fprintf(fpgoods,"\t\t\t\t\t\t商品信息列表\n"); //商品信息的录入 for (i = 0; i < inumber; i++) { fprintf(fpgoods,"名称: %s\n",a[i].name); fprintf(fpgoods,"货号: %d\n",a[i].number); fprintf(fpgoods,"厂家: %s\n",a[i].vender); fprintf(fpgoods,"产地: %s\n",a[i].filed); fprintf(fpgoods,"存量: %d\n",a[i].stock); fprintf(fpgoods,"单价: %.2lf\n\n\n",a[i].price); } fclose(fpgoods); printf("\n\n\n\n\n\n\t\t\t\t商品信息保存成功!!!\n"); printf("\t\t\t\t"); return; } //订单的保存信息 void savedinggou() { FILE *fpgoods; int i; fpgoods = fopen("bookrecordinfo.out","w"); fprintf(fpgoods,"\t\t\t\t\t\t订单列表\n"); //商品信息的录入 for (i = 0; i < ibuy; i++) { fprintf(fpgoods,"货号 :%d\n",b[i].bgname); fprintf(fpgoods,"订购量 :%d\n",b[i].bmany); fprintf(fpgoods,"日期时间 :%d\n",b[i].btime); fprintf(fpgoods,"客户名 :%s\n",b[i].bname); fprintf(fpgoods,"客户地址 :%s\n",b[i].baddress); fprintf(fpgoods,"客户号 :%d\n\n\n",b[i].bnumber); } fclose(fpgoods); //保存后信息的反馈 printf("\n\n\n\n\n\n\t\t\t\t信息保存成功!!!\n"); printf("\t\t\t\t"); return; }

c语言实训课程选修管理系统

1.题目描述 编写一个程序对学生的课程选修进行管理。系统能实现以下功能:  添加:添加课程或学生记录,可提供选择所要添加类别的选择界面,要求编号要唯一,如果添加了重复编号的记录时,则提示数据添加重复并取消添加;  查询:可根据编号、姓名等信息对已有的学生或课程基本信息进行查询;查询选修某门课程的学生;查询某学生学期选修的课程;如果未找到,给出相应的提示信息,如果找到,则显示相应的记录信息。可提供选择界面供用户选择;  显示:可显示已有学生或课程的信息,每条记录占据一行;  编辑:可根据查询结果对相应的记录进行修改,修改时注意编号的唯一性;  删除:对已有的学生或课程记录进行删除。如果当前系统中没有相应的记录,则提示“记录为空!”并返回操作;  统计:能根据多种参数进行统计。如能统计某学期开设的课程数,选修某门课程的实际学生人数,选修某门课程的男女生比例,某门课程的平均成绩,某学生学期选修的课程数等;  排序:能根据多种参数进行排序。如对某门课程按实际选修人数升序/降序排序,对某门课程按学生成绩升序/降序排序等;  保存:将当前系统中各类记录存入文件中,存入方式任意;  读取:可将保存在文件中的信息读入到当前系统中,供用户使用。 2.设计提示 (1)学生基本信息包括:学号、班级、姓名、性别、联系方式等信息。课程基本信息包括:课程代码、课程名称、课程性质、总学时、学分、开课学期、选修人数等信息; (2)划分实现课程选修管理的功能模块:如主菜单、添加、修改、查询、统计、保存等功能,并确定各功能模块的实现算法; (3)确定课程选修的数据结构,至少应包括课程代码、学号和课程成绩等; (4)画出主要算法的流程图; (5)选择C语言的技术:普通数组、结构体数组、函数、指针、单链表或文件等; (6)编写程序代码。

c语言问题:使用c语言制作学生信息管理系统

基础功能: 1,学生信息(学号,姓名,性别,班级,电话) 2,添增(包括插入)学生信息 3,删除学生信息 4,查找学生信息(查询一个\全部学生信息) 5,修改学生信息 6,每个功能封装成单独的函数 7,适当的提示(“请输入学号”这类的)

C语言编程实现:从键盘上读取任意长度的 一段文本,确定该文本中每个单词的出现频率

C语言编程实现:从键盘上读取任意长度的 一段文本,确定该文本中每个单词的出现频率

c语言实现英文文本词频统计

c语言结课课程设计,希望有大佬可以指点一下小白 单词词频统计 设计内容: 写程序处理英语文本文件,统计文件中所出现的各单词在文本中出现的频次。 设计功能: 1、 将英文段落以文本文件,并在屏幕上显示。 2、 处理读入的文本文件,提取段落中的英文单词,并且统计各单词出现的次数。 3、 将各单词及其出现频次打印出来,并且将频次为前十的单词的频率用柱状图表示出来。 如果VC6.0环境不能画柱状图的话,就只需要把所有单词的出现频次打出来,再把前十的单词和频率输出就好。 求指电 跪求大佬帮助

数据结构课程设计用C语言做

据结构课程设计。包含word,或txt文档阅读。 读的“内容”,请保存到任意一门课上所讲的表中。可以是sqlist,LinkList,sqstack,queue等要求能用逗号句号分行显示并且输入1 2 3 4 可以对应显示每行的内容

c语言编程题目: 回文素数(望解答)

编程任务编号 I: 回文素数(基础版) 时间限制: 1 Sec 内存限制: 64 MB 提交: 1588 解决: 765 [提交][裁判情况] [答疑讨论区] 任务描述 11是一个回文素数.因为它不仅是素数,同时还是回文数(回文数,即把一个数字正着读或者倒着读都是一样的,如121,1331等都是回文数). 现在写一个程序把a的b之间所有的回文素数都找出来(2≤a<b≤1000,000). 输入 第一行,一个整数N(N<10) 以下N行,每行两个整数a,b. 输出 输出回文素数的列表,每行一个,按从小到大的顺序输出. 输入举例 1 5 200 输出举例 5 7 11 101 131 151 181 191

做一个统计工资的C语言课程设计 急 在线等

本课程设计要求设计一个公司职员的数据结构,并使用结构指针数组存储职员信息,统计公司员工工资总额和平均工资。 2.2 设计要求 设计要求实现如下功能: (1)使用结构指针数组设计一个公司职员的数据结构,使用下述的结构定义: typedef struct employee{ int age; char *name; double salary; }*PEMP; (2)在主函数里构造一个指针数组company,用来存放职工信息。 (3)设计一个update函数,用来给company赋值。 函数update(company, id, age, name, salary)的四个参数为: company: 结构指针数组 id: company的下标 age: 年龄,整数类型 salary: 薪水,实数 (4)设计一个readin函数,直接采用调用update函数的方式进行赋值。例如:update(company, 2, 30, “LI MING”, 3000.0); (5)编写total函数对工资求和。 这个函数应该能对全体职工和某一年龄段的职工的工资求和。 6)编写mean函数求平均工资。 这个函数应该能对全体职工和大于某一年龄段的职工的工资求和并计算相应的平均值。

C语言编程:商家商品销售量统计

现在有一个网站上半年的商品销售量,请你写一段代码帮助店主统计前半年的总销量和平均销量。 商品销售表 1月份 2月份 3月份 4月份 5月份 6月份 总销量 平均销量 64 53 77 59 61 42 0 0 (1)函数中应定义一个包含8个元素的一维数据,用来存放6个月的商品销量和统计后的总销量及平均销量; (2)完成6个月销量的输入; (3)计算半年的总销量及平均销量; (4)按照程序运行效果图,输出商品销量表。 ![图片说明](https://img-ask.csdn.net/upload/202005/16/1589596638_852927.jpg)

我需要做一个C语言课程设计是图书管理系统 但有错误不会改,各位大神能帮我改改吗? 谢谢了

#include<stdio.h> #include<stdlib.h> #include<string.h> /*********图书信息结构体*********/ /***包括登录号,书名,作者名,分类号,出版单位,出版时间,价格等***/ struct bookinf { int num; ///登录号 char bname[20];// 书名 char wname[10];//作者名 char clanum[14];//分类号 char pubcom[10];// 出版单位 char pubtime[10];// 出版时间 float price;//价格 }; /***显示主菜单信息模块***/ /***来到图书信息管理系统页面***/ void index() { char input; //运行时 printf("\n\n\t\t\t*****************************\n"); //直接进入 printf("\t\t\t图书信息管理系统\n"); //这个页面? printf("\t\t\t*****************************\n\n\n"); printf("------------------------------------------\n"); printf("\t<按任意键进入>\n\t"); input=getchar(); } /***管理员登陆进入功能菜单页面***/ FILE *fp; if ((fp=fopen("password.txt","r"))==NULL) { printf("\n\n\n\tCannot open file!\n\t"); return ; } else { do { printf("\n\n\t请输入管理员帐号:"); scanf("%s",name); printf("\n\n\t请输入管理员密码:"); scanf("%s",password); fp=fopen("password.txt","r"); fread(&pswd,sizeof(struct manage),1,fp); fclose(fp); w=strcmp(pswd.manage_name,name); k=strcmp(pswd.password,password); adm_servelist(); } while (w!=0||k!=0); adm_servelist(); } /*来到功能菜单页面*/ void adm_servelist() { void book_add(); void book_view(); void change(); void del(); void book_search(); void login(); void pwchange(); int in; char input; do { printf("\n\n\n\t--欢迎使用信息管理系统--"); printf("\n\n\t1.图书信息录入\n"); printf("\t2.图书信息浏览\n"); printf("\t3.图书信息查询\n"); printf("\t4.图书信息删除\n"); printf("\t5.图书信息修改\n"); printf("\t6.退出管理模式\n"); printf("\n\t请选择服务种类:"); scanf("%d",&in); if (in!=1&&in!=2&&in!=3&&in!=4&&in!=5&&in!=6) { printf("\n\t没有这项服务~\n"); printf("\t按任意键重新选择"); input=getchar(); } } while (in!=1&&in!=2&&in!=3&&in!=4&&in!=5&&in!=6); switch (in) { case 1: book_add(); break; case 2: book_view(); break; case 3: book_search(); break; case 4: del(); break; case 5: change();break; case 6: login(); break; } } /*添加图书信息模块*/ void book_add() { void adm_servelist(); int i=0,j; FILE *fp; char input; struct bookinf books; struct bookinf book_taxis[30]; printf("\n\n\n\t---请输入图书信息---\n\n"); printf("\t登录号:"); scanf("%d",&books.num); printf("\n\t书名:"); scanf("%s",books.bname); printf("\n\t作者名:"); scanf("%s",books.wname); printf("\n\t分类号:"); scanf("%s",books.clanum); printf("\n\t出版单位:"); scanf("%s",books.pubcom); printf("\n\t出版时间:"); scanf("%s",books.pubtime); printf("\n\t价格:"); scanf("%f",&books.price); if ((fp=fopen("book.txt","r"))!=NULL) { do { fread(&book_taxis[i],sizeof(struct bookinf),1,fp); i=i+1; } while(!feof(fp)); fclose(fp); for (j=0;j<=i;j++) if (books.num==book_taxis[j].num) { printf("\n\n\n\t对不起,这个编号已经使用过了~\n"); printf("\t按任意键返回管理菜单~"); input=getchar(); adm_servelist(); break; } } if ((fp=fopen("book.txt","r"))==NULL) { fp=fopen("book.txt","w"); } else { fclose(fp); fp=fopen("book.txt","a"); } fwrite(&books,sizeof(struct bookinf),1,fp); fclose(fp); printf("\n\n\n\t信息输入完毕~按任意键继续\n"); input=getchar(); adm_servelist(); } /*显示所有图书信息模块*/ void book_view() { void adm_servelist(); void book_view(); int inp,i=0,n=0; FILE *fp; char input; struct bookinf bookview[20]; if ((fp=fopen("book.txt","r"))==NULL) { printf("\n\n\n\t数据尚未初始化~~\n\n\t请在管理菜单中增加图书信息~~~\n"); printf("\n\t<按任意键返回管理菜单>\n\t"); input=getchar(); adm_servelist(); } else { do { fread(&bookview[i],sizeof(struct bookinf),1,fp); i=i+1; } while (!feof(fp)); fclose(fp); do { printf("\n\t--------共有%d条记录--------",i-1); printf("\n\n\t登录号: %d\n",bookview[n].num); printf("\n\t书名: %s\n",bookview[n].bname); printf("\n\t作者名: %s\n",bookview[n].wname); printf("\n\t分类号: %s\n",bookview[n].clanum); printf("\n\t出版单位: %s\n",bookview[n].pubcom); printf("\n\t出版时间: %s\n",bookview[n].pubtime); printf("\n\t价格: %f\n",bookview[n].price); printf("\n\n\t1.上一页\t2.下一页\t3.回目录\n"); printf("\n\t请选择:"); scanf("%d",&inp); switch (inp) { case 1: { if (n==0) { printf("\n\t已到达首页\n\t按任意键重新选择"); input=getchar(); } else n=n-1; break; } case 2: { if (n==i-2) { printf("\n\t已到达最末页\n\t按任意键重新选择"); input=getchar(); } else n=n+1; break; } case 3: { adm_servelist(); break; } default: { printf("\n\t没有这项服务\n\t按任意键重新选择"); input=getchar(); } } } while (inp!=3); } } //修改图书信息模块: void change(int x) { int inp,i=0,j; void book_search(); FILE *fp,*fp1; char input; struct bookinf books,book_taxis[20]; do { printf("\n\n\n\t注意:您确定要修改该记录吗?\n"); printf("\n\t1.是\t2.否\n"); printf("\n\t请输入:"); scanf("%d",&inp); if (inp!=1&&inp!=2) { printf("\n\t对不起~没有这项服务~\n"); printf("\t按任意键重新选择\n\t"); input=getchar(); } } while (inp!=1&&inp!=2); if (inp==2) book_search(); if (inp==1) { printf("\n\n\n\t---请输入图书信息---\n\n"); printf("\t登录号:"); scanf("%d",&books.num); printf("\n\t书名:"); scanf("%s",books.bname); printf("\n\t作者名:"); scanf("%s",books.wname); printf("\n\t分类号:"); scanf("%s",books.clanum); printf("\n\t出版单位:"); scanf("%s",books.pubcom); printf("\n\t出版时间:"); scanf("%s",books.pubtime); printf("\n\t价格:"); scanf("%f",&books.price); if ((fp1=fopen("book.txt","r"))!=NULL) { do { fread(&book_taxis[i],sizeof(struct bookinf),1,fp1); i=i+1; } while(!feof(fp1)); fclose(fp1); for (j=0;j<x;j++) if (books.num==book_taxis[j].num) { printf("\n\n\n\t对不起,这个编号已经使用过了~\n"); printf("\t按任意键返回管理菜单~"); printf("0"); input=getchar(); book_search(); break; } for (j=x+1;j<i-2;j++) if (books.num==book_taxis[j].num) { printf("\n\n\n\t对不起,这个编号已经使用过了~\n"); printf("1"); printf("\t按任意键返回管理菜单~"); input=getchar(); book_search(); break; } } book_taxis[x]=books; fp=fopen("book.txt","w"); for (j=0;j<i-1;j++) fwrite(&book_taxis[j],sizeof(struct bookinf),1,fp); fclose(fp); printf("\n\n\t信息修改完成!按任意键返回"); input=getchar(); book_search(); } } //删除图书信息模块 void del(int y) { char input; FILE *fp; int inp,i=0,j; struct bookinf book_taxis[20]; void book_search(); void adm_servelist(); do { printf("\n\n\n\t注意:您确定要删除该记录吗?\n"); printf("\n\t1.是\t2.否\n"); printf("\n\t请输入:"); scanf("%d",&inp); if (inp!=1&&inp!=2) { printf("\n\t对不起~没有这项服务~\n"); printf("\t按任意键重新选择\n\t"); input=getchar(); } } while (inp!=1&&inp!=2); if (inp==2) book_search(); if (inp==1) { if ((fp=fopen("book.txt","r"))!=NULL) { do { fread(&book_taxis[i],sizeof(struct bookinf),1,fp); i=i+1; } while(!feof(fp)); fclose(fp); } if (i>2) { fp=fopen("book.txt","w"); for (j=0;j<y;j++) fwrite(&book_taxis[j],sizeof(struct bookinf),1,fp); fclose(fp); fp=fopen("book.txt","a"); for (j=y+1;j<i-1;j++) fwrite(&book_taxis[j],sizeof(struct bookinf),1,fp); fclose(fp); } else { remove("book.txt"); } printf("\n\n\t记录已删除!\n\n\t按任意键返回\n\t"); input=getchar(); adm_servelist(); } } /*查询图书信息模块*/ void book_search() { void adm_servelist(); void id_search(); void wr_search(); void bn_search(); char input; FILE *fp; int inp; if ((fp=fopen("book.txt","r"))==NULL) { printf("\n\n\n\t数据尚未初始化~~\n\n\t请在管理菜单中增加图书信息~~~\n"); printf("\n\t<按任意键返回管理菜单>\n\t"); input=getchar(); adm_servelist(); } else { do { printf("\n\n\n\t1.按图书登录号查询\n"); printf("\n\t2.按图书作者查询\n"); printf("\n\t3.按图书名查询\n"); printf("\n\t4.回到主菜单\n"); printf("\n\n\t请选择查询类别:"); scanf("%d",&inp); if (inp!=1&&inp!=2&&inp!=3&&inp!=4) { printf("\n\n\t没有这项服务~\n\t按任意键重新选择~"); input=getchar(); } } while (inp!=1&&inp!=2&&inp!=3&&inp!=4); fclose(fp); switch (inp) { case 1: id_search(); break; case 2: wr_search(); break; case 3: bn_search(); break; case 4: adm_servelist(); break; } } } >**(主要的错误是E:\大学\c语言\C语言课程设计\综合题.c(30) : error C2059: syntax error : 'if' E:\大学\c语言\C语言课程设计\综合题.c(35) : error C2059: syntax error : 'else')**

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

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

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

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

CSDN:因博主近期注重写专栏文章(已超过150篇),订阅博主专栏人数在突增,近期很有可能提高专栏价格(已订阅的不受影响),提前声明,敬请理解!

CSDN:因博主近期注重写专栏文章(已超过150篇),订阅博主专栏人数在突增,近期很有可能提高专栏价格(已订阅的不受影响),提前声明,敬请理解! 目录 博客声明 大数据了解博主粉丝 博主的粉丝群体画像 粉丝群体性别比例、年龄分布 粉丝群体学历分布、职业分布、行业分布 国内、国外粉丝群体地域分布 博主的近期访问每日增量、粉丝每日增量 博客声明 因近期博主写专栏的文章越来越多,也越来越精细,逐步优化文章。因此,最近一段时间,订阅博主专栏的人数增长也非常快,并且专栏价

我说我不会算法,阿里把我挂了。

不说了,字节跳动也反手把我挂了。

培训班出来的人后来都怎么样了?(二)

接着上回说,培训班学习生涯结束了。后面每天就是无休止的背面试题,不是没有头脑的背,培训公司还是有方法的,现在回想当时背的面试题好像都用上了,也被问到了。回头找找面试题,当时都是打印下来天天看,天天背。 不理解呢也要背,面试造飞机,上班拧螺丝。班里的同学开始四处投简历面试了,很快就有面试成功的,刚开始一个,然后越来越多。不知道是什么原因,尝到胜利果实的童鞋,不满足于自己通过的公司,嫌薪水要少了,选择...

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

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

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

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

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

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

工作八年,月薪60K,裸辞两个月,投简历投到怀疑人生!

近日,有网友在某职场社交平台吐槽,自己裸辞两个月了,但是找工作却让自己的心态都要崩溃了,全部无果,不是已查看无回音,就是已查看不符合。 “工作八年,两年一跳,裸辞两个月了,之前月薪60K,最近找工作找的心态崩了!所有招聘工具都用了,全部无果,不是已查看无回音,就是已查看不符合。进头条,滴滴之类的大厂很难吗???!!!投简历投的开始怀疑人生了!希望 可以收到大厂offer” 先来看看网...

97年世界黑客编程大赛冠军作品(大小仅为16KB),惊艳世界的编程巨作

这是世界编程大赛第一名作品(97年Mekka ’97 4K Intro比赛)汇编语言所写。 整个文件只有4095个字节, 大小仅仅为16KB! 不仅实现了3D动画的效果!还有一段震撼人心的背景音乐!!! 内容无法以言语形容,实在太强大! 下面是代码,具体操作看最后! @echo off more +1 %~s0|debug e100 33 f6 bf 0 20 b5 10 f3 a5...

不要再到处使用 === 了

我们知道现在的开发人员都使用 === 来代替 ==,为什么呢?我在网上看到的大多数教程都认为,要预测 JavaScript 强制转换是如何工作这太复杂了,因此建议总是使用===。这些都...

什么是a站、b站、c站、d站、e站、f站、g站、h站、i站、j站、k站、l站、m站、n站?00后的世界我不懂!

A站 AcFun弹幕视频网,简称“A站”,成立于2007年6月,取意于Anime Comic Fun,是中国大陆第一家弹幕视频网站。A站以视频为载体,逐步发展出基于原生内容二次创作的完整生态,拥有高质量互动弹幕,是中国弹幕文化的发源地;拥有大量超粘性的用户群体,产生输出了金坷垃、鬼畜全明星、我的滑板鞋、小苹果等大量网络流行文化,也是中国二次元文化的发源地。 B站 全称“哔哩哔哩(bilibili...

终于,月薪过5万了!

来看几个问题想不想月薪超过5万?想不想进入公司架构组?想不想成为项目组的负责人?想不想成为spring的高手,超越99%的对手?那么本文内容是你必须要掌握的。本文主要详解bean的生命...

MySQL性能优化(五):为什么查询速度这么慢

前期回顾: MySQL性能优化(一):MySQL架构与核心问题 MySQL性能优化(二):选择优化的数据类型 MySQL性能优化(三):深入理解索引的这点事 MySQL性能优化(四):如何高效正确的使用索引 前面章节我们介绍了如何选择优化的数据类型、如何高效的使用索引,这些对于高性能的MySQL来说是必不可少的。但这些还完全不够,还需要合理的设计查询。如果查询写的很糟糕,即使表结构再合理、索引再...

用了这个 IDE 插件,5分钟解决前后端联调!

点击上方蓝色“程序猿DD”,选择“设为星标”回复“资源”获取独家整理的学习资料!作者 |李海庆我是一个 Web 开发前端工程师,受到疫情影响,今天是我在家办公的第78天。开发了两周,...

大厂的 404 页面都长啥样?最后一个笑了...

每天浏览各大网站,难免会碰到404页面啊。你注意过404页面么?猿妹搜罗来了下面这些知名网站的404页面,以供大家欣赏,看看哪个网站更有创意: 正在上传…重新上传取消 腾讯 正在上传…重新上传取消 网易 淘宝 百度 新浪微博 正在上传…重新上传取消 新浪 京东 优酷 腾讯视频 搜...

【高并发】高并发秒杀系统架构解密,不是所有的秒杀都是秒杀!

网上很多的文章和帖子中在介绍秒杀系统时,说是在下单时使用异步削峰来进行一些限流操作,那都是在扯淡! 因为下单操作在整个秒杀系统的流程中属于比较靠后的操作了,限流操作一定要前置处理,在秒杀业务后面的流程中做限流操作是没啥卵用的。

自从喜欢上了B站这12个UP主,我越来越觉得自己是个废柴了!

不怕告诉你,我自从喜欢上了这12个UP主,哔哩哔哩成为了我手机上最耗电的软件,几乎每天都会看,可是吧,看的越多,我就越觉得自己是个废柴,唉,老天不公啊,不信你看看…… 间接性踌躇满志,持续性混吃等死,都是因为你们……但是,自己的学习力在慢慢变强,这是不容忽视的,推荐给你们! 都说B站是个宝,可是有人不会挖啊,没事,今天咱挖好的送你一箩筐,首先啊,我在B站上最喜欢看这个家伙的视频了,为啥 ,咱撇...

代码注释如此沙雕,会玩还是你们程序员!

某站后端代码被“开源”,同时刷遍全网的,还有代码里的那些神注释。 我们这才知道,原来程序员个个都是段子手;这么多年来,我们也走过了他们的无数套路… 首先,产品经理,是永远永远吐槽不完的!网友的评论也非常扎心,说看这些代码就像在阅读程序员的日记,每一页都写满了对产品经理的恨。 然后,也要发出直击灵魂的质问:你是尊贵的付费大会员吗? 这不禁让人想起之前某音乐app的穷逼Vip,果然,穷逼在哪里都是...

Java14 新特性解读

Java14 已于 2020 年 3 月 17 号发布,官方特性解读在这里:https://openjdk.java.net/projects/jdk/14/以下是个人对于特性的中文式...

爬虫(101)爬点重口味的

小弟最近在学校无聊的很哪,浏览网页突然看到一张图片,都快流鼻血。。。然后小弟冥思苦想,得干一点有趣的事情python 爬虫库安装https://s.taobao.com/api?_ks...

疫情后北上广深租房价格跌了吗? | Alfred数据室

去年3月份我们发布了《北上广深租房图鉴》(点击阅读),细数了北上广深租房的各种因素对租房价格的影响。一年过去了,在面临新冠疫情的后续影响、城市尚未完全恢复正常运转、学校还没开学等情况下...

面试官给我挖坑:a[i][j] 和 a[j][i] 有什么区别?

点击上方“朱小厮的博客”,选择“设为星标”后台回复&#34;1024&#34;领取公众号专属资料本文以一个简单的程序开头——数组赋值:int LEN = 10000; int[][] ...

又一起程序员被抓事件

就在昨天互联网又发生一起让人心酸的程序员犯罪事件,著名的百度不限速下载软件 Pandownload PC 版作者被警方抓获。案件大致是这样的:软件的作者不仅非法盗取用户数据,还在QQ群进...

应聘3万的职位,有必要这么刁难我么。。。沙雕。。。

又一次被面试官带到坑里面了。面试官:springmvc用过么?我:用过啊,经常用呢面试官:springmvc中为什么需要用父子容器?我:嗯。。。没听明白你说的什么。面试官:就是contr...

太狠了,疫情期间面试,一个问题砍了我5000!

疫情期间找工作确实有点难度,想拿到满意的薪资,确实要点实力啊!面试官:Spring中的@Value用过么,介绍一下我:@Value可以标注在字段上面,可以将外部配置文件中的数据,比如可以...

Intellij IDEA 美化指南

经常有人问我,你的 IDEA 配色哪里搞的,我会告诉他我自己改的。作为生产力工具,不但要顺手而且更要顺眼。这样才能快乐编码,甚至降低 BUG 率。上次分享了一些 IDEA 有用的插件,反...

【相亲】96年程序员小哥第一次相亲,还没开始就结束了

颜值有点高,条件有点好

太厉害了,终于有人能把TCP/IP 协议讲的明明白白了

一图看完本文 一、 计算机网络体系结构分层 计算机网络体系结构分层 计算机网络体系结构分层 不难看出,TCP/IP 与 OSI 在分层模块上稍有区别。OSI 参考模型注重“通信协议必要的功能是什么”,而 TCP/IP 则更强调“在计算机上实现协议应该开发哪种程序”。 二、 TCP/IP 基础 1. TCP/IP 的具体含义 从字面意义上讲,有人可能会认为...

腾讯面试题: 百度搜索为什么那么快?

我还记得去年面腾讯时,面试官最后一个问题是:百度/google的搜索为什么那么快? 这个问题我懵了,我从来没想过,搜素引擎的原理是什么 然后我回答:百度爬取了各个网站的信息,然后进行排序,当输入关键词的时候进行文档比对……巴拉巴拉 面试官:这不是我想要的答案 我内心 这个问题我一直耿耿于怀,终于今天,我把他写出来,以后再问,我直接把这篇文章甩给他!!! 两个字:倒排,将贯穿整篇文章,也是面试官...

相关热词 c# 局部 截图 页面 c#实现简单的文件管理器 c# where c# 取文件夹路径 c# 对比 当天 c# fir 滤波器 c# 和站 队列 c# txt 去空格 c#移除其他类事件 c# 自动截屏
立即提问