经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 程序设计 » C 语言 » 查看文章
C语言实现员工工资管理系统
来源:jb51  时间:2022/2/28 8:51:32  对本文有异议

本文实例为大家分享了C语言实现员工工资管理系统的具体代码,供大家参考,具体内容如下

看点:

1. 枚举类型的使用(录入与输出)

2. 文件的使用:用文件来存储员工信息,开始运行程序时从文件中读取员工信息到链表退出程序时将员工信息保存到文件中。

2_1. 存储结构体这样的数据块所使用的文件操作函数;

2_2. feof()函数作为循环条件的正确使用方法;

3. 链表的相关操作

3_1. 结构体中char类型的数据写入方式

4. while循环下实现的菜单与子菜单

注:部分功能还没有实现,涉及到单链表的遍历,比较简单。

头文件:标头.h

  1. #include<malloc.h>
  2. #include<stdio.h>
  3. #include<stdlib.h>
  4. #include<string.h>
  5. //枚举型岗位:销售员、技术员、销售经理、经理
  6. enum workpost { SALESMAN = 0, TECHNICIAN, SALESMANAGER, MANAGER };
  7. //员工类型:链表结点
  8. struct Employee {
  9. ?? ?int ?id;?? ??? ??? ??? ?//员工号:主键,唯一
  10. ?? ?char name[10];?? ??? ??? ?//姓名
  11. ?? ?char sex[3];?? ??? ??? ?//性别:男或女
  12. ?? ?int ?age;?? ??? ??? ??? ?//年龄
  13. ?? ?char department[20];?? ?//部门
  14. ?? ?enum workpost post;?? ??? ?//枚举型岗位
  15. ?? ?int ?workHour;?? ??? ??? ?//当月工作小时数
  16. ?? ?double sales;?? ??? ??? ?//当月月销售额
  17. ?? ?double salary;?? ??? ??? ?//月工资
  18. ?? ?struct Employee * next;//链表的指针域
  19. };
  20. #define LENGTH 50
  21. //全局变量
  22. Employee Employees[LENGTH];
  23. typedef int DataType;
  24. Employee *head;
  25. int select = 1;//功能选择变量
  26. int subselect = 1;//子功能选择变量
  27. FILE *fp;
  28. int i = 0;//循环变量
  29. //函数声明
  30. void ListInitiate(Employee **head);
  31. void Load();
  32. void Check();
  33. void AddData();
  34. void UpdataData();
  35. void QueryData();
  36. void DeleteData();
  37. void Sorting();
  38. void Statistics();
  39. void Save();
  40. //菜单函数
  41. ? //要求:至少有两层菜单。
  42. void Menu()
  43. {
  44. ?? ?while (select)
  45. ?? ?{
  46. ?? ??? ?printf("————————员工工资管理系统————————\n");
  47. ?? ??? ?printf("————1. 增添数据 ? ? ? ? ? 2. 修改数据————\n");
  48. ?? ??? ?printf("————3. 查找数据 ? ? ? ? ? 4. 删除数据————\n");
  49. ?? ??? ?printf("————5. 排序函数 ? ? ? ? ? 6. 统计数据————\n");
  50. ?? ??? ?printf("————0. 退出程序 ? ? ? ? ? 7. 查看链表————\n");
  51. ?? ??? ?printf("请输入你的选择:\n");
  52. ?? ??? ?scanf("%d", &select);
  53. ?? ??? ?switch (select)
  54. ?? ??? ?{
  55. ?? ??? ?case 1:
  56. ?? ??? ??? ?AddData();
  57. ?? ??? ??? ?break;
  58. ?? ??? ?case 2:
  59. ?? ??? ??? ?UpdataData();
  60. ?? ??? ??? ?break;
  61. ?? ??? ?case 3:
  62. ?? ??? ??? ?QueryData();
  63. ?? ??? ??? ?break;
  64. ?? ??? ?case 4:
  65. ?? ??? ??? ?DeleteData();
  66. ?? ??? ??? ?break;
  67. ?? ??? ?case 5:
  68. ?? ??? ??? ?Sorting();
  69. ?? ??? ??? ?break;
  70. ?? ??? ?case 6:
  71. ?? ??? ??? ?Statistics();
  72. ?? ??? ??? ?break;
  73. ?? ??? ?case 7:
  74. ?? ??? ??? ?Check();
  75. ?? ??? ??? ?break;
  76. ?? ??? ?case 0: break;
  77. ?? ??? ?default: printf("输入错误!请重新选择。\n");
  78. ?? ??? ?}
  79. ?? ?}
  80. }
  81. //功能函数
  82. ? //初始化链表函数
  83. void ListInitiate(Employee **head)//head是一个指针,*head也是一个指针
  84. {
  85. ?? ?*head = (Employee *)malloc(sizeof(Employee));//申请头结点
  86. ?? ?(*head)->next = NULL;
  87. }
  88. //必须用文件来存储员工信息:
  89. ?? ?//开始运行程序时从文件中读取员工信息到链表,退出程序时将员工信息保存到文件中。
  90. void Load() {
  91. ?? ?if ((fp = fopen("Employee.txt", "ab+")) == NULL)
  92. ?? ?{
  93. ?? ??? ?printf("打开文件出错!\n");
  94. ?? ??? ?exit(1);
  95. ?? ?}
  96. ?? ?//未知文件长度,使用feof(FILE *Stream)判断文件结尾
  97. ?? ?while (!feof(fp))
  98. ?? ?{
  99. ?? ??? ?//feof(fp)通过fread/fscanf是否读写出错判断,应该在读写操作之后进行判断,否则多进行一轮循环
  100. ?? ??? ?if (fread(&Employees[i], sizeof(struct Employee), 1, fp) == 0)
  101. ?? ??? ?{
  102. ?? ??? ??? ?continue;
  103. ?? ??? ?}
  104. ?? ??? ?Employee *p, *q;//分别用于指向第i个结点和待插入的新结点
  105. ?? ??? ?p = head;
  106. ?? ??? ?while (p->next != NULL)//把指针P定位到链表尾位置
  107. ?? ??? ?{
  108. ?? ??? ??? ?p = p->next;
  109. ?? ??? ?}
  110. ?? ??? ?q = (Employee *)malloc(sizeof(Employee));//用指针Q申请新结点
  111. ?? ??? ?//存入数据到链表结点
  112. ?? ??? ?q->id = i;
  113. ?? ??? ?q->id++;
  114. ?? ??? ?strcpy(q->name, Employees[i].name);
  115. ?? ??? ?strcpy(q->sex, Employees[i].sex);
  116. ?? ??? ?q->age = Employees[i].age;
  117. ?? ??? ?strcpy(q->department, Employees[i].department);
  118. ?? ??? ?q->post = Employees[i].post;
  119. ?? ??? ?q->workHour = Employees[i].workHour;
  120. ?? ??? ?q->sales = Employees[i].sales;//当月月销售额
  121. ?? ??? ?q->salary = Employees[i].salary;//月工资
  122. ?? ??? ?q->next = p->next;//Q指针的next域指向P指针的next域,即第i个结点
  123. ?? ??? ?p->next = q;
  124. ?? ??? ?i++;
  125. ?? ?}
  126. ?? ?fclose(fp);
  127. }
  128. //检查链表数据输入是否准确
  129. void Check()
  130. {
  131. ?? ?Employee *p;
  132. ?? ?p = head;
  133. ?? ?if (p->next == NULL)
  134. ?? ?{
  135. ?? ??? ?printf("链表为空!\n");
  136. ?? ?}
  137. ?? ?else
  138. ?? ?{
  139. ?? ??? ?printf("链表数据内容为:\n");
  140. ?? ??? ?while (p->next != NULL)
  141. ?? ??? ?{
  142. ?? ??? ??? ?p = p->next;
  143. ?? ??? ??? ?printf("%d %s %s %d %s ", p->id, p->name, p->sex, p->age, p->department);
  144. ?? ??? ??? ?switch (p->post)
  145. ?? ??? ??? ?{
  146. ?? ??? ??? ?case 0:
  147. ?? ??? ??? ??? ?printf("SALESMAN ? ?");
  148. ?? ??? ??? ??? ?break;
  149. ?? ??? ??? ?case 1:
  150. ?? ??? ??? ??? ?printf("TECHNICIAN ?");
  151. ?? ??? ??? ??? ?break;
  152. ?? ??? ??? ?case 2:
  153. ?? ??? ??? ??? ?printf("SALESMANAGER");
  154. ?? ??? ??? ??? ?break;
  155. ?? ??? ??? ?case 3:
  156. ?? ??? ??? ??? ?printf("MANAGER ? ? ");
  157. ?? ??? ??? ??? ?break;
  158. ?? ??? ??? ?default:
  159. ?? ??? ??? ??? ?printf("数据有误!\n");
  160. ?? ??? ??? ??? ?break;
  161. ?? ??? ??? ?}
  162. ?? ??? ??? ?printf(" %d ?%.2lf ?%.2lf\n", p->workHour, p->sales, p->salary);
  163. ?? ??? ?}
  164. ?? ??? ?printf("输出完毕!\n");
  165. ?? ?}
  166. }
  167. //增添数据
  168. ? //添加一个员工,只输入该员工的基本信息(姓名、年龄、性别、部门、岗位)。
  169. void AddData()
  170. {
  171. ?? ?Employee *p, *q;//分别用于指向第i个结点和待插入的新结点
  172. ?? ?p = head;
  173. ?? ?while (p->next != NULL)//把指针P定位到链表尾位置
  174. ?? ?{
  175. ?? ??? ?p = p->next;
  176. ?? ?}
  177. ?? ?q = (Employee *)malloc(sizeof(Employee));//用指针Q申请新结点
  178. ?? ?i++;
  179. ?? ?q->id = i;
  180. ?? ?printf("请输入员工姓名:\n");
  181. ?? ?scanf("%s", q->name);
  182. ?? ?printf("请输入员工年龄:\n");
  183. ?? ?scanf("%d", &q->age);
  184. ?? ?printf("请输入员工性别:\n");
  185. ?? ?scanf("%s", q->sex);
  186. ?? ?printf("请输入员工部门:\n");
  187. ?? ?scanf("%s", q->department);
  188. ?? ?printf("请输入员工岗位:\n");
  189. ?? ?scanf("%d", &q->post);
  190. ?? ?q->workHour = 0;
  191. ?? ?if (q->post == 3)
  192. ?? ?{
  193. ?? ??? ?q->salary = 8000.0;
  194. ?? ?}
  195. ?? ?else
  196. ?? ?{
  197. ?? ??? ?q->salary = 0.0;
  198. ?? ?}
  199. ?? ?q->sales = 0.0;
  200. ?? ?q->next = p->next;//Q指针的next域指向P指针的next域,即第i个结点
  201. ?? ?p->next = q;
  202. ?? ?printf("添加成功!\n");
  203. }
  204. //修改数据
  205. /*
  206. 1)根据员工号来修改任意员工的基本信息(姓名、年龄、性别、部门、岗位)。
  207. 2)批量计算所有技术员的当月工资额(需填写技术员当月工作时间)。
  208. 3)批量计算所有销售员的当月工资额(需填写销售员当月销售额);然后批量计算所有销售经理的当月工资额。
  209. */
  210. void UpdataData()
  211. {
  212. ?? ?subselect = 1;
  213. ?? ?Employee *p, *p1;
  214. ?? ?p = head;
  215. ?? ?while (subselect)
  216. ?? ?{
  217. ?? ??? ?printf("—————— ?修改数据的二级菜单 ?——————\n");
  218. ?? ??? ?printf("——1. 根据员工号来修改任意员工的基本信息\n");
  219. ?? ??? ?printf("——2. 批量计算所有技术员的当月工资额\n");
  220. ?? ??? ?printf("——3. 批量计算所有销售员的当月工资额,然后批量计算所有销售经理的当月工资额\n");
  221. ?? ??? ?printf("——0. 退出此子菜单\n");
  222. ?? ??? ?printf("请输入你的选择:\n");
  223. ?? ??? ?scanf("%d", &subselect);
  224. ?? ??? ?switch (subselect)
  225. ?? ??? ?{
  226. ?? ??? ?case 1:
  227. ?? ??? ??? ?p = head;
  228. ?? ??? ??? ?int ID;
  229. ?? ??? ??? ?printf("请输入待修改的员工信息的员工号:\n");
  230. ?? ??? ??? ?scanf("%d", &ID);
  231. ?? ??? ??? ?while (p->next != NULL)
  232. ?? ??? ??? ?{
  233. ?? ??? ??? ??? ?p = p->next;
  234. ?? ??? ??? ??? ?if (p->id == ID)
  235. ?? ??? ??? ??? ?{
  236. ?? ??? ??? ??? ??? ?printf("请输入新的员工姓名:\n");
  237. ?? ??? ??? ??? ??? ?scanf("%s", p->name);
  238. ?? ??? ??? ??? ??? ?printf("请输入新的员工年龄:\n");
  239. ?? ??? ??? ??? ??? ?scanf("%d", &p->age);
  240. ?? ??? ??? ??? ??? ?printf("请输入新的员工性别:\n");
  241. ?? ??? ??? ??? ??? ?scanf("%s", p->sex);
  242. ?? ??? ??? ??? ??? ?printf("请输入新的员工部门:\n");
  243. ?? ??? ??? ??? ??? ?scanf("%s", p->department);
  244. ?? ??? ??? ??? ??? ?printf("请输入新的员工岗位:\n");
  245. ?? ??? ??? ??? ??? ?scanf("%d", &p->post);
  246. ?? ??? ??? ??? ??? ?printf("信息录入成功!\n");
  247. ?? ??? ??? ??? ??? ?break;
  248. ?? ??? ??? ??? ?}
  249. ?? ??? ??? ?}
  250. ?? ??? ??? ?break;
  251. ?? ??? ?case 2:
  252. ?? ??? ??? ?//批量计算所有技术员的当月工资额,技术员工资:工作时间*小时工资(100元每小时)
  253. ?? ??? ??? ?p = head;
  254. ?? ??? ??? ?while (p->next != NULL)
  255. ?? ??? ??? ?{
  256. ?? ??? ??? ??? ?p = p->next;
  257. ?? ??? ??? ??? ?if (p->post == 1)
  258. ?? ??? ??? ??? ?{
  259. ?? ??? ??? ??? ??? ?printf("请填写员工号为%d的技术员当月工作时间:\n", p->id);
  260. ?? ??? ??? ??? ??? ?scanf("%d", &p->workHour);
  261. ?? ??? ??? ??? ??? ?p->salary = p->workHour * 100;
  262. ?? ??? ??? ??? ?}
  263. ?? ??? ??? ?}
  264. ?? ??? ??? ?break;
  265. ?? ??? ?case 3:
  266. ?? ??? ??? ?//销售员工资:销售额*4%提成;
  267. ?? ??? ??? ?p = head;
  268. ?? ??? ??? ?while (p->next != NULL)
  269. ?? ??? ??? ?{
  270. ?? ??? ??? ??? ?p = p->next;
  271. ?? ??? ??? ??? ?if (p->post == 0)
  272. ?? ??? ??? ??? ?{
  273. ?? ??? ??? ??? ??? ?printf("请填写员工号为%d的销售员当月销售额:\n", p->id);
  274. ?? ??? ??? ??? ??? ?scanf("%lf", &p->sales);
  275. ?? ??? ??? ??? ??? ?p->salary = p->sales*0.04;
  276. ?? ??? ??? ??? ?}
  277. ?? ??? ??? ?}?
  278. ?? ??? ??? ?//销售经理:底薪(5000)+所辖部门销售额总额*0.5%。
  279. ?? ??? ??? ?p = head;
  280. ?? ??? ??? ?while (p->next != NULL)
  281. ?? ??? ??? ?{
  282. ?? ??? ??? ??? ?p = p->next;
  283. ?? ??? ??? ??? ?p1 = head;
  284. ?? ??? ??? ??? ?double sum_of_sales = 0.0;
  285. ?? ??? ??? ??? ?if (p->post == 2)
  286. ?? ??? ??? ??? ?{
  287. ?? ??? ??? ??? ?while(p1->next != NULL)
  288. ?? ??? ??? ??? ?{
  289. ?? ??? ??? ??? ??? ?p1 = p1->next;
  290. ?? ??? ??? ??? ? ? ?if (strcmp(p->department, p1->department)==0)
  291. ?? ??? ??? ??? ? ? ?{
  292. ?? ??? ??? ??? ??? ? ? sum_of_sales += p1->sales ;
  293. ?? ??? ??? ??? ? ? ?}
  294. ?? ??? ??? ??? ?}
  295. ?? ??? ??? ??? ?p->salary = sum_of_sales * 0.005 + 5000;
  296. ?? ??? ??? ??? ?}
  297. ?? ??? ??? ?}
  298. ?? ??? ??? ?break;
  299. ?? ??? ?case 0:
  300. ?? ??? ??? ?break;
  301. ?? ??? ?default:
  302. ?? ??? ??? ?printf("输入错误!请重新选择。\n");
  303. ?? ??? ?}
  304. ?? ?}
  305. }
  306. //查询数据
  307. void QueryData()
  308. {
  309. ?? ?subselect = 1;
  310. ?? ?Employee *p;
  311. ?? ?p = head;
  312. ?? ?while (subselect)
  313. ?? ?{
  314. ?? ??? ?printf("—————— ?查询数据的二级菜单 ? ——————\n");
  315. ?? ??? ?printf("——1. 根据工号或者姓名查询员工信息\n");
  316. ?? ??? ?printf("——2. 按部门显示本部门全部员工信息\n");
  317. ?? ??? ?printf("——3. 分别显示4种岗位的员工信息\n");
  318. ?? ??? ?printf("——4. 分页显示全部员工的信息\n");
  319. ?? ??? ?printf("——0. 退出此子菜单\n");
  320. ?? ??? ?printf("请输入你的选择:\n");
  321. ?? ??? ?scanf("%d", &subselect);
  322. ?? ??? ?switch (subselect)
  323. ?? ??? ?{
  324. ?? ??? ?case 1:
  325. ?? ??? ??? ?p = head;
  326. ?? ??? ??? ?int ID;
  327. ?? ??? ??? ?printf("请输入工号:\n");
  328. ?? ??? ??? ?scanf("%d", &ID);
  329. ?? ??? ??? ?while (p->next != NULL)
  330. ?? ??? ??? ?{
  331. ?? ??? ??? ??? ?p = p->next;
  332. ?? ??? ??? ??? ?if (p->id == ID)
  333. ?? ??? ??? ?{
  334. ?? ??? ??? ?printf("%d %s %s %d %s ", p->id, p->name, p->sex, p->age, p->department);
  335. ?? ??? ??? ?switch (p->post)
  336. ?? ??? ??? ?{
  337. ?? ??? ??? ?case 0:
  338. ?? ??? ??? ??? ?printf("SALESMAN ? ?");
  339. ?? ??? ??? ??? ?break;
  340. ?? ??? ??? ?case 1:
  341. ?? ??? ??? ??? ?printf("TECHNICIAN ?");
  342. ?? ??? ??? ??? ?break;
  343. ?? ??? ??? ?case 2:
  344. ?? ??? ??? ??? ?printf("SALESMANAGER");
  345. ?? ??? ??? ??? ?break;
  346. ?? ??? ??? ?case 3:
  347. ?? ??? ??? ??? ?printf("MANAGER ? ? ");
  348. ?? ??? ??? ??? ?break;
  349. ?? ??? ??? ?default:
  350. ?? ??? ??? ??? ?printf("数据有误!\n");
  351. ?? ??? ??? ??? ?break;
  352. ?? ??? ??? ?}
  353. ?? ??? ??? ?printf(" %d ?%.2lf ?%.2lf\n", p->workHour, p->sales, p->salary);
  354. ?? ??? ? ? ?printf("输出完毕!\n");
  355. ?? ? ? ? ? ?}
  356. ?? ? ? ? ? ?}
  357. ?? ??? ?break;
  358. ?? ??? ?case 2:
  359. ?? ??? ??? ?char Department[20];
  360. ?? ??? ??? ?printf("请输入部门名称:\n");
  361. ?? ??? ??? ??? ??? ?scanf("%s", &Department);
  362. ?? ??? ??? ?p = head;
  363. ?? ??? ??? ?while(p->next != NULL)
  364. ?? ??? ??? ??? ?{
  365. ?? ??? ??? ??? ??? ?p = p->next;
  366. ?? ??? ??? ??? ? ? ?if (strcmp(p->department, Department)==0)
  367. ?? ??? ??? ??? ? ? ?{
  368. ?? ??? ??? ??? ??? ? ? printf("%d %s %s %d %s ", p->id, p->name, p->sex, p->age, p->department);
  369. ?? ??? ??? ?switch (p->post)
  370. ?? ??? ??? ?{
  371. ?? ??? ??? ?case 0:
  372. ?? ??? ??? ??? ?printf("SALESMAN ? ?");
  373. ?? ??? ??? ??? ?break;
  374. ?? ??? ??? ?case 1:
  375. ?? ??? ??? ??? ?printf("TECHNICIAN ?");
  376. ?? ??? ??? ??? ?break;
  377. ?? ??? ??? ?case 2:
  378. ?? ??? ??? ??? ?printf("SALESMANAGER");
  379. ?? ??? ??? ??? ?break;
  380. ?? ??? ??? ?case 3:
  381. ?? ??? ??? ??? ?printf("MANAGER ? ? ");
  382. ?? ??? ??? ??? ?break;
  383. ?? ??? ??? ?default:
  384. ?? ??? ??? ??? ?printf("数据有误!\n");
  385. ?? ??? ??? ??? ?break;
  386. ?? ??? ??? ?}
  387. ?? ??? ??? ?printf(" %d ?%.2lf ?%.2lf\n", p->workHour, p->sales, p->salary);
  388. ?? ??? ??? ??? ? ? ?}
  389. ?? ??? ??? ??? ?}
  390. ?? ??? ??? ??? ?printf("输出完毕!\n");
  391. ?? ??? ??? ?
  392. ?? ??? ?break;
  393. ?? ??? ?case 3:
  394. ?? ??? ??? ?printf("SALESMAN:\n");
  395. ?? ??? ??? ?p = head;
  396. ?? ??? ??? ?while (p->next != NULL)
  397. ?? ??? ??? ?{
  398. ?? ??? ??? ??? ?p = p->next;
  399. ?? ??? ??? ??? ?if (p->post==0)
  400. ?? ??? ??? ??? ? ? ?{
  401. ?? ??? ??? ??? ??? ? ? printf("%d %s %s %d %s ", p->id, p->name, p->sex, p->age, p->department);
  402. ?? ??? ??? ?switch (p->post)
  403. ?? ??? ??? ?{
  404. ?? ??? ??? ?case 0:
  405. ?? ??? ??? ??? ?printf("SALESMAN ? ?");
  406. ?? ??? ??? ??? ?break;
  407. ?? ??? ??? ?case 1:
  408. ?? ??? ??? ??? ?printf("TECHNICIAN ?");
  409. ?? ??? ??? ??? ?break;
  410. ?? ??? ??? ?case 2:
  411. ?? ??? ??? ??? ?printf("SALESMANAGER");
  412. ?? ??? ??? ??? ?break;
  413. ?? ??? ??? ?case 3:
  414. ?? ??? ??? ??? ?printf("MANAGER ? ? ");
  415. ?? ??? ??? ??? ?break;
  416. ?? ??? ??? ?default:
  417. ?? ??? ??? ??? ?printf("数据有误!\n");
  418. ?? ??? ??? ??? ?break;
  419. ?? ??? ??? ?}
  420. ?? ??? ??? ?printf(" %d ?%.2lf ?%.2lf\n", p->workHour, p->sales, p->salary);
  421. ?? ??? ??? ??? ? ? ?}
  422. ?? ??? ??? ?}?
  423. ?? ??? ??? ?printf("TECHNICIAN:\n");
  424. ?? ??? ??? ?p = head;
  425. ?? ??? ??? ?while (p->next != NULL)
  426. ?? ??? ??? ?{
  427. ?? ??? ??? ??? ?p = p->next;
  428. ?? ??? ??? ??? ?if (p->post==1)
  429. ?? ??? ??? ??? ? ? ?{
  430. ?? ??? ??? ??? ??? ? ? printf("%d %s %s %d %s ", p->id, p->name, p->sex, p->age, p->department);
  431. ?? ??? ??? ?switch (p->post)
  432. ?? ??? ??? ?{
  433. ?? ??? ??? ?case 0:
  434. ?? ??? ??? ??? ?printf("SALESMAN ? ?");
  435. ?? ??? ??? ??? ?break;
  436. ?? ??? ??? ?case 1:
  437. ?? ??? ??? ??? ?printf("TECHNICIAN ?");
  438. ?? ??? ??? ??? ?break;
  439. ?? ??? ??? ?case 2:
  440. ?? ??? ??? ??? ?printf("SALESMANAGER");
  441. ?? ??? ??? ??? ?break;
  442. ?? ??? ??? ?case 3:
  443. ?? ??? ??? ??? ?printf("MANAGER ? ? ");
  444. ?? ??? ??? ??? ?break;
  445. ?? ??? ??? ?default:
  446. ?? ??? ??? ??? ?printf("数据有误!\n");
  447. ?? ??? ??? ??? ?break;
  448. ?? ??? ??? ?}
  449. ?? ??? ??? ?printf(" %d ?%.2lf ?%.2lf\n", p->workHour, p->sales, p->salary);
  450. ?? ??? ??? ??? ? ? ?}
  451. ?? ??? ??? ?}?
  452. ?? ??? ??? ?printf("SALESMANAGER:\n");
  453. ?? ??? ??? ?p = head;
  454. ?? ??? ??? ?while (p->next != NULL)
  455. ?? ??? ??? ?{
  456. ?? ??? ??? ??? ?p = p->next;
  457. ?? ??? ??? ??? ?if (p->post==2)
  458. ?? ??? ??? ??? ? ? ?{
  459. ?? ??? ??? ??? ??? ? ? printf("%d %s %s %d %s ", p->id, p->name, p->sex, p->age, p->department);
  460. ?? ??? ??? ?switch (p->post)
  461. ?? ??? ??? ?{
  462. ?? ??? ??? ?case 0:
  463. ?? ??? ??? ??? ?printf("SALESMAN ? ?");
  464. ?? ??? ??? ??? ?break;
  465. ?? ??? ??? ?case 1:
  466. ?? ??? ??? ??? ?printf("TECHNICIAN ?");
  467. ?? ??? ??? ??? ?break;
  468. ?? ??? ??? ?case 2:
  469. ?? ??? ??? ??? ?printf("SALESMANAGER");
  470. ?? ??? ??? ??? ?break;
  471. ?? ??? ??? ?case 3:
  472. ?? ??? ??? ??? ?printf("MANAGER ? ? ");
  473. ?? ??? ??? ??? ?break;
  474. ?? ??? ??? ?default:
  475. ?? ??? ??? ??? ?printf("数据有误!\n");
  476. ?? ??? ??? ??? ?break;
  477. ?? ??? ??? ?}
  478. ?? ??? ??? ?printf(" %d ?%.2lf ?%.2lf\n", p->workHour, p->sales, p->salary);
  479. ?? ??? ??? ??? ? ? ?}
  480. ?? ??? ??? ?}?
  481. ?? ??? ??? ?printf("MANAGER:\n");
  482. ?? ??? ??? ?p = head;
  483. ?? ??? ??? ?while (p->next != NULL)
  484. ?? ??? ??? ?{
  485. ?? ??? ??? ??? ?p = p->next;
  486. ?? ??? ??? ??? ?if (p->post==3)
  487. ?? ??? ??? ??? ? ? ?{
  488. ?? ??? ??? ??? ??? ? ? printf("%d %s %s %d %s ", p->id, p->name, p->sex, p->age, p->department);
  489. ?? ??? ??? ?switch (p->post)
  490. ?? ??? ??? ?{
  491. ?? ??? ??? ?case 0:
  492. ?? ??? ??? ??? ?printf("SALESMAN ? ?");
  493. ?? ??? ??? ??? ?break;
  494. ?? ??? ??? ?case 1:
  495. ?? ??? ??? ??? ?printf("TECHNICIAN ?");
  496. ?? ??? ??? ??? ?break;
  497. ?? ??? ??? ?case 2:
  498. ?? ??? ??? ??? ?printf("SALESMANAGER");
  499. ?? ??? ??? ??? ?break;
  500. ?? ??? ??? ?case 3:
  501. ?? ??? ??? ??? ?printf("MANAGER ? ? ");
  502. ?? ??? ??? ??? ?break;
  503. ?? ??? ??? ?default:
  504. ?? ??? ??? ??? ?printf("数据有误!\n");
  505. ?? ??? ??? ??? ?break;
  506. ?? ??? ??? ?}
  507. ?? ??? ??? ?printf(" %d ?%.2lf ?%.2lf\n", p->workHour, p->sales, p->salary);
  508. ?? ??? ??? ??? ? ? ?}
  509. ?? ??? ??? ?}?
  510. ?? ??? ??? ?printf("输出完毕!\n");
  511. ?? ??? ?break;
  512. ?? ??? ?case 4:
  513. ?? ??? ??? ?printf("分页功能略难(没学过),暂时留空吧\n");
  514. ?? ??? ?break;
  515. ?? ??? ?case 0:
  516. ?? ??? ?break;
  517. ?? ??? ?default:
  518. ?? ??? ?printf("输入错误!请重新选择。\n");
  519. ?? ??? ?}
  520. ? ? }
  521. ?? ?
  522. }
  523. //删除数据
  524. void DeleteData(){
  525. ?? ?Employee *p, *s;
  526. ?? ?p = head;
  527. ?? ?printf("请输入要删除员工信息的员工号:\n");
  528. ?? ?scanf("%d", &i);
  529. ?? ?while (p->next != NULL)
  530. ?? ?{
  531. ?? ??? ?s = p;
  532. ?? ??? ?p = p->next;
  533. ?? ??? ?if(p->id==i) break;?? ?
  534. ?? ?}
  535. ?? ?s->next = s->next->next;
  536. ?? ?free(p);
  537. }
  538. ?
  539. //按要求排序
  540. void Sorting()
  541. {
  542. ?? ?subselect = 1;
  543. ?? ?Employee *p, *p1;
  544. ?? ?int z = 0;
  545. ?? ?int f=0;
  546. ?? ?int count = 0;
  547. ?? ?double s[20];
  548. ?? ?double storeNum;
  549. ?? ?p = head;
  550. ?? ?while (subselect)
  551. ?? ?{
  552. ?? ??? ?printf("—————— ?排序数据的二级菜单 ? ——————\n");
  553. ?? ??? ?printf("——1. 所有员工信息按当月工资从高到低并显示\n");
  554. ?? ??? ?printf("——2. 某个岗位的员工信息按当月工资从高到低显示\n");
  555. ?? ??? ?printf("——0. 退出此子菜单\n");
  556. ?? ??? ?printf("请输入你的选择:\n");
  557. ?? ??? ?scanf("%d", &subselect);
  558. ?? ??? ?switch (subselect)
  559. ?? ??? ?{
  560. ?? ??? ?case 1:
  561. ?? ??? ??? ?p = head;
  562. ?? ??? ??? ?z = 0;?
  563. ?? ??? ??? ?while (p->next != NULL)
  564. ?? ??? ??? ?{
  565. ?? ??? ??? ??? ?p = p->next;
  566. ?? ??? ??? ??? ?s[z] = p->salary;
  567. ?? ??? ??? ??? ?z++;
  568. ?? ??? ??? ?}
  569. ?? ??? ??? ?//冒泡排序?
  570. ?? ??? ??? ?for (int i = 0; i < z-1; i++)//因为进行两两比较,10个数最坏的情况就需要进行9趟
  571. ?? ? ? ? ? ?{
  572. ?? ??? ? ? ?for (int j = 0; j < (z-1) - i; j++)//因为每进行一趟就可以排好一个数,所以循环次数-i
  573. ?? ??? ? ? ?{
  574. ?? ??? ??? ?if (s[j] > s[j+1])//两两比较
  575. ?? ??? ??? ?{
  576. ?? ??? ??? ??? ?double temp = s[j];
  577. ?? ??? ??? ??? ?s[j] = s[j+1];
  578. ?? ??? ??? ??? ?s[j+1] = temp;
  579. ?? ??? ??? ?}
  580. ?? ??? ? ? ?}
  581. ?? ? ? ? ? ?}
  582. ?? ? ? ? ? ?z--;
  583. ?? ??? ??? ?for (int i = z; i >= 0; i--)
  584. ?? ??? ??? ?{
  585. ?? ??? ??? ??? ?if(storeNum == s[i])
  586. ?? ??? ??? ??? ?{
  587. ?? ??? ??? ??? ??? ?continue;
  588. ?? ??? ??? ??? ?}
  589. ?? ??? ??? ? ? ?p = head;
  590. ?? ??? ??? ? ? ?while (p->next != NULL)
  591. ?? ??? ??? ? ? ?{
  592. ?? ??? ??? ??? ?p = p->next;
  593. ?? ??? ??? ? ? ?storeNum = s[i];
  594. ?? ??? ??? ??? ?if(p->salary==s[i])
  595. ?? ??? ??? ??? ?{
  596. ?? ??? ??? ??? ??? ?printf("%d %s %s %d %s ", p->id, p->name, p->sex, p->age, p->department);
  597. ?? ??? ??? ?switch (p->post)
  598. ?? ??? ??? ?{
  599. ?? ??? ??? ?case 0:
  600. ?? ??? ??? ??? ?printf("SALESMAN ? ?");
  601. ?? ??? ??? ??? ?break;
  602. ?? ??? ??? ?case 1:
  603. ?? ??? ??? ??? ?printf("TECHNICIAN ?");
  604. ?? ??? ??? ??? ?break;
  605. ?? ??? ??? ?case 2:
  606. ?? ??? ??? ??? ?printf("SALESMANAGER");
  607. ?? ??? ??? ??? ?break;
  608. ?? ??? ??? ?case 3:
  609. ?? ??? ??? ??? ?printf("MANAGER ? ? ");
  610. ?? ??? ??? ??? ?break;
  611. ?? ??? ??? ?default:
  612. ?? ??? ??? ??? ?printf("数据有误!\n");
  613. ?? ??? ??? ??? ?break;
  614. ?? ??? ??? ?}
  615. ?? ??? ??? ?printf(" %d ?%.2lf ?%.2lf\n", p->workHour, p->sales, p->salary);
  616. ?? ??? ??? ??? ?}
  617. ?? ??? ??? ?}
  618. ?? ??? ?}
  619. ?? ??? ?break;?? ?
  620. ?? ??? ?case 2:
  621. ?? ??? ??? ?int Post;
  622. ?? ??? ??? ?z = 0;
  623. ?? ??? ??? ?storeNum = 0.0;
  624. ?? ??? ??? ?printf("请输入岗位信息:(SALESMAN = 0, TECHNICIAN, SALESMANAGER, MANAGER)\n");
  625. ?? ??? ??? ?scanf("%d", &Post);
  626. ?? ??? ??? ?p = head;
  627. ?? ??? ??? ?while(p->next != NULL)
  628. ?? ??? ??? ??? ?{
  629. ?? ??? ??? ??? ??? ?p = p->next;
  630. ?? ??? ??? ??? ? ? ?if (p->post==Post)
  631. ?? ??? ??? ??? ? ? ?{
  632. ?? ??? ??? ??? ? ? ??? ?s[z] = p->salary;
  633. ?? ??? ??? ??? ? ? ? ? ?z++;
  634. ?? ??? ??? ? ? ? ? }
  635. ?? ? ? ? ? ??? ?}
  636. ?? ??? ??? ?//冒泡排序?
  637. ?? ??? ??? ?for (int i = 0; i < z-1; i++)
  638. ?? ? ? ? ? ?{
  639. ?? ??? ? ? ?for (int j = 0; j < (z-1) - i; j++)//因为每进行一趟就可以排好一个数,所以循环次数-i
  640. ?? ??? ? ? ?{
  641. ?? ??? ??? ?if (s[j] > s[j+1])//两两比较
  642. ?? ??? ??? ?{
  643. ?? ??? ??? ??? ?double temp = s[j];
  644. ?? ??? ??? ??? ?s[j] = s[j+1];
  645. ?? ??? ??? ??? ?s[j+1] = temp;
  646. ?? ??? ??? ?}
  647. ?? ??? ? ? ?}
  648. ?? ? ? ? ? ?}
  649. ?? ? ? ? ? ?z--;
  650. ?? ? ? ? ? ?for (int i = z; i >= 0; i--)
  651. ?? ??? ??? ?{
  652. ?? ??? ??? ??? ?if(storeNum == s[i])
  653. ?? ??? ??? ??? ?{
  654. ?? ??? ??? ??? ??? ?continue;
  655. ?? ??? ??? ??? ?}
  656. ?? ??? ??? ? ? ?p = head;
  657. ?? ??? ??? ? ? ?while (p->next != NULL)
  658. ?? ??? ??? ? ? ?{
  659. ?? ??? ??? ??? ?p = p->next;
  660. ?? ??? ??? ??? ?if(p->salary==s[i]&&p->post==Post)
  661. ?? ??? ??? ??? ?{
  662. ?? ??? ??? ??? ??? ?storeNum = s[i];
  663. ?? ??? ??? ??? ??? ?printf("%d %s %s %d %s ", p->id, p->name, p->sex, p->age, p->department);
  664. ?? ??? ??? ?switch (p->post)
  665. ?? ??? ??? ?{
  666. ?? ??? ??? ?case 0:
  667. ?? ??? ??? ??? ?printf("SALESMAN ? ?");
  668. ?? ??? ??? ??? ?break;
  669. ?? ??? ??? ?case 1:
  670. ?? ??? ??? ??? ?printf("TECHNICIAN ?");
  671. ?? ??? ??? ??? ?break;
  672. ?? ??? ??? ?case 2:
  673. ?? ??? ??? ??? ?printf("SALESMANAGER");
  674. ?? ??? ??? ??? ?break;
  675. ?? ??? ??? ?case 3:
  676. ?? ??? ??? ??? ?printf("MANAGER ? ? ");
  677. ?? ??? ??? ??? ?break;
  678. ?? ??? ??? ?default:
  679. ?? ??? ??? ??? ?printf("数据有误!\n");
  680. ?? ??? ??? ??? ?break;
  681. ?? ??? ??? ?}
  682. ?? ??? ??? ?printf(" %d ?%.2lf ?%.2lf\n", p->workHour, p->sales, p->salary);
  683. ?? ??? ??? ??? ?}
  684. ?? ??? ??? ?}
  685. ?? ? ? ? ?? ?}?? ??? ? ? ??? ?
  686. ?? ??? ?break;
  687. ?? ??? ?case 0:
  688. ?? ??? ?break;
  689. ?? ??? ?default:
  690. ?? ??? ?printf("输入错误!请重新选择。\n");
  691. ?? ?}
  692. ? ? }?? ?
  693. }
  694. //统计数据
  695. void Statistics()
  696. {
  697. ?? ?printf("hh\n");
  698. }
  699. //保存链表数据到文件
  700. void Save()
  701. {
  702. ?? ?Employee *p;
  703. ?? ?p = head;
  704. ?? ?i = 0;
  705. ?? ?//第一步将链表中的结点信息存入数组中
  706. ?? ?while (p->next != NULL)
  707. ?? ?{
  708. ?? ??? ?p = p->next;
  709. ?? ??? ?Employees[i].id = p->id;
  710. ?? ??? ?strcpy(Employees[i].name, p->name);
  711. ?? ??? ?strcpy(Employees[i].sex, p->sex);
  712. ?? ??? ?Employees[i].age = p->age;
  713. ?? ??? ?strcpy(Employees[i].department, p->department);
  714. ?? ??? ?Employees[i].post = p->post;
  715. ?? ??? ?Employees[i].workHour = p->workHour;
  716. ?? ??? ?Employees[i].sales = p->sales;//当月月销售额
  717. ?? ??? ?Employees[i].salary = p->salary;//月工资
  718. ?? ??? ?i++;
  719. ?? ?}
  720. ?? ?//第二步将数组数据录入文本文件
  721. ?? ?if ((fp = fopen("employee.txt", "wb+")) == NULL)
  722. ?? ?{
  723. ?? ??? ?printf("打开文件出错!\n");
  724. ?? ??? ?exit(1);
  725. ?? ?}
  726. ?? ?p = head;
  727. ?? ?i = 0;
  728. ?? ?while (p->next != NULL)
  729. ?? ?{
  730. ?? ??? ?p = p->next;
  731. ?? ??? ?if (fwrite(&Employees[i], sizeof(struct Employee), 1, fp) != 1)
  732. ?? ??? ?{
  733. ?? ??? ??? ?printf("写入文件出错!\n");
  734. ?? ??? ?}
  735. ?? ??? ?i++;
  736. ?? ?}
  737. ?? ?fclose(fp);
  738. ?? ?printf("成功保存数据到文本文件employee\n");
  739. }

Main函数:

  1. #include"标头.h"
  2. int main()
  3. {
  4. ?? ?ListInitiate(&head);
  5. ?? ?Load();//加载已有的数据到链表
  6. ?? ?Menu();
  7. ?? ?Save();//保存数据到文件
  8. ?? ?printf("欢迎下次使用!\n");
  9. }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持w3xue。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号