c语言网购管理系统

时间: 2023-07-03 21:05:10 浏览: 108
一个简单的 C 语言网购管理系统可以包括以下功能: 1. 商品管理:包括添加、删除、修改商品信息,查询商品列表等功能; 2. 订单管理:包括添加、删除、修改订单信息,查询订单列表等功能; 3. 用户管理:包括添加、删除、修改用户信息,查询用户列表等功能; 4. 支付管理:包括支付方式选择、支付结果查询等功能; 5. 物流管理:包括物流公司选择、物流运输状态查询等功能。 其中,可以使用文件存储数据,也可以使用数据库存储数据。具体实现方式可以根据需求选择。 下面是一个简单的代码示例,仅供参考: ```c #include <stdio.h> #include <stdlib.h> #include <string.h> #define MAX_PRODUCT_NUM 100 // 最大商品数量 #define MAX_ORDER_NUM 100 // 最大订单数量 #define MAX_USER_NUM 100 // 最大用户数量 // 商品结构体 typedef struct { char name[50]; // 商品名称 float price; // 商品价格 int stock; // 商品库存 } Product; // 订单结构体 typedef struct { int id; // 订单编号 char product_name[50]; // 商品名称 int quantity; // 商品数量 float total_price; // 订单总价 char status[20]; // 订单状态 } Order; // 用户结构体 typedef struct { char name[50]; // 用户名称 char address[100]; // 用户地址 char phone[20]; // 用户手机号码 } User; // 商品列表 Product products[MAX_PRODUCT_NUM]; int product_count = 0; // 订单列表 Order orders[MAX_ORDER_NUM]; int order_count = 0; // 用户列表 User users[MAX_USER_NUM]; int user_count = 0; // 添加商品 void add_product() { printf("请输入商品名称:"); scanf("%s", products[product_count].name); printf("请输入商品价格:"); scanf("%f", &products[product_count].price); printf("请输入商品库存:"); scanf("%d", &products[product_count].stock); product_count++; printf("添加成功!\n"); } // 删除商品 void delete_product() { char name[50]; printf("请输入要删除的商品名称:"); scanf("%s", name); int i, j; for (i = 0; i < product_count; i++) { if (strcmp(products[i].name, name) == 0) { for (j = i; j < product_count - 1; j++) { products[j] = products[j + 1]; } product_count--; printf("删除成功!\n"); return; } } printf("未找到该商品!\n"); } // 修改商品信息 void modify_product() { char name[50]; printf("请输入要修改的商品名称:"); scanf("%s", name); int i; for (i = 0; i < product_count; i++) { if (strcmp(products[i].name, name) == 0) { printf("请输入新的商品名称:"); scanf("%s", products[i].name); printf("请输入新的商品价格:"); scanf("%f", &products[i].price); printf("请输入新的商品库存:"); scanf("%d", &products[i].stock); printf("修改成功!\n"); return; } } printf("未找到该商品!\n"); } // 查询商品列表 void query_product_list() { int i; printf("商品列表:\n"); for (i = 0; i < product_count; i++) { printf("%s\t%.2f\t%d\n", products[i].name, products[i].price, products[i].stock); } } // 添加订单 void add_order() { printf("请输入商品名称:"); scanf("%s", orders[order_count].product_name); printf("请输入商品数量:"); scanf("%d", &orders[order_count].quantity); int i; for (i = 0; i < product_count; i++) { if (strcmp(products[i].name, orders[order_count].product_name) == 0) { if (orders[order_count].quantity > products[i].stock) { printf("商品库存不足!\n"); return; } orders[order_count].id = order_count + 1; orders[order_count].total_price = orders[order_count].quantity * products[i].price; strcpy(orders[order_count].status, "待支付"); products[i].stock -= orders[order_count].quantity; order_count++; printf("添加成功!\n"); return; } } printf("未找到该商品!\n"); } // 删除订单 void delete_order() { int id; printf("请输入要删除的订单编号:"); scanf("%d", &id); int i, j; for (i = 0; i < order_count; i++) { if (orders[i].id == id) { for (j = i; j < order_count - 1; j++) { orders[j] = orders[j + 1]; } order_count--; printf("删除成功!\n"); return; } } printf("未找到该订单!\n"); } // 修改订单信息 void modify_order() { int id; printf("请输入要修改的订单编号:"); scanf("%d", &id); int i; for (i = 0; i < order_count; i++) { if (orders[i].id == id) { printf("请输入新的商品名称:"); scanf("%s", orders[i].product_name); printf("请输入新的商品数量:"); scanf("%d", &orders[i].quantity); int j; for (j = 0; j < product_count; j++) { if (strcmp(products[j].name, orders[i].product_name) == 0) { if (orders[i].quantity > products[j].stock) { printf("商品库存不足!\n"); return; } orders[i].total_price = orders[i].quantity * products[j].price; products[j].stock -= orders[i].quantity; printf("修改成功!\n"); return; } } printf("未找到该商品!\n"); return; } } printf("未找到该订单!\n"); } // 查询订单列表 void query_order_list() { int i; printf("订单列表:\n"); for (i = 0; i < order_count; i++) { printf("%d\t%s\t%d\t%.2f\t%s\n", orders[i].id, orders[i].product_name, orders[i].quantity, orders[i].total_price, orders[i].status); } } // 添加用户 void add_user() { printf("请输入用户名称:"); scanf("%s", users[user_count].name); printf("请输入用户地址:"); scanf("%s", users[user_count].address); printf("请输入用户手机号码:"); scanf("%s", users[user_count].phone); user_count++; printf("添加成功!\n"); } // 删除用户 void delete_user() { char name[50]; printf("请输入要删除的用户名称:"); scanf("%s", name); int i, j; for (i = 0; i < user_count; i++) { if (strcmp(users[i].name, name) == 0) { for (j = i; j < user_count - 1; j++) { users[j] = users[j + 1]; } user_count--; printf("删除成功!\n"); return; } } printf("未找到该用户!\n"); } // 修改用户信息 void modify_user() { char name[50]; printf("请输入要修改的用户名称:"); scanf("%s", name); int i; for (i = 0; i < user_count; i++) { if (strcmp(users[i].name, name) == 0) { printf("请输入新的用户名称:"); scanf("%s", users[i].name); printf("请输入新的用户地址:"); scanf("%s", users[i].address); printf("请输入新的用户手机号码:"); scanf("%s", users[i].phone); printf("修改成功!\n"); return; } } printf("未找到该用户!\n"); } // 查询用户列表 void query_user_list() { int i; printf("用户列表:\n"); for (i = 0; i < user_count; i++) { printf("%s\t%s\t%s\n", users[i].name, users[i].address, users[i].phone); } } // 支付订单 void pay_order() { int id; printf("请输入要支付的订单编号:"); scanf("%d", &id); int i; for (i = 0; i < order_count; i++) { if (orders[i].id == id) { if (strcmp(orders[i].status, "待支付") == 0) { strcpy(orders[i].status, "已支付"); printf("支付成功!\n"); return; } else { printf("该订单已支付!\n"); return; } } } printf("未找到该订单!\n"); } // 查询物流信息 void query_logistics() { int id; printf("请输入要查询的订单编号:"); scanf("%d", &id); int i; for (i = 0; i < order_count; i++) { if (orders[i].id == id) { printf("物流公司:顺丰速运\n"); printf("物流单号:SF%d\n", id); if (strcmp(orders[i].status, "已支付") == 0) { printf("物流状态:已发货\n"); } else { printf("物流状态:未发货\n"); } return; } } printf("未找到该订单!\n"); } int main() { int choice; while (1) { printf("1.商品管理\n2.订单管理\n3.用户管理\n4.支付管理\n5.物流管理\n0.退出程序\n"); printf("请选择操作:"); scanf("%d", &choice); switch (choice) { case 1: printf("1.添加商品\n2.删除商品\n3.修改商品信息\n4.查询商品列表\n"); printf("请选择操作:"); scanf("%d", &choice); switch (choice) { case 1: add_product(); break; case 2: delete_product(); break; case 3: modify_product(); break; case 4: query_product_list(); break; default: printf("无效操作!\n"); break; } break; case 2: printf("1.添加订单\n2.删除订单\n3.修改订单信息\n4.查询订单列表\n"); printf("请选择操作:"); scanf("%d", &choice); switch (choice) { case 1: add_order(); break; case 2: delete_order(); break; case 3: modify_order(); break; case 4: query_order_list(); break; default: printf("无效操作!\n"); break; } break; case 3: printf("1.添加用户\n2.删除用户\n3.修改用户信息\n4.查询用户列表\n"); printf("请选择操作:"); scanf("%d", &choice); switch (choice) { case 1: add_user(); break; case 2: delete_user(); break; case 3: modify_user(); break; case 4: query_user_list(); break; default: printf("无效操作!\n"); break; } break; case 4: printf("1.支付订单\n"); printf("请选择操作:"); scanf("%d", &choice); switch (choice) { case 1: pay_order(); break; default: printf("无效操作!\n"); break; } break; case 5: printf("1.查询物流信息\n"); printf("请选择操作:"); scanf("%d", &choice); switch (choice) { case 1: query_logistics(); break; default: printf("无效操作!\n"); break; } break; case 0: return 0; default: printf("无效操作!\n"); break; } } return 0; } ```
阅读全文

相关推荐

txt
#include #include #include #include #define ID struct id struct id { char name[20]; // xing ming int num; // xue hao int age; // nian ling char sex[2]; // xing bie char xi[20]; // xi bie char zhuan[20]; // zhuan ye char add[20]; // di zhi ID *next; // }; // FILE *fp; // ID *head; int sum_age=0,max_age=0,min_age=100,pc=0; float ave_age=0; ID *creat() { ID *p1,*p2,*head; int pd; p1=p2=head=NULL; printf("\t\t\t 开始输入记录!!!\n"); printf("please input pd:\n"); scanf("%d",&pd); while(pd!=0) { p1=(ID*)malloc(sizeof(ID)); printf("请输入学生的学号:\n");scanf("%d",&p1->num); printf("请输入学生的姓名:\n");scanf("%s",p1->name); printf("请输入学生的年龄:\n");scanf("%d",&p1->age); sum_age+=p1->age; if(max_ageage) max_age=p1->age; if(min_age>p1->age) min_age=p1->age; printf("请输入学生的性别:\n");scanf("%s",p1->sex); printf("请输入学生的系别:\n");scanf("%s",p1->xi); printf("请输入学生的专业:\n");scanf("%s",p1->zhuan); printf("请输入学生的地址:\n");scanf("%s",&p1->add); if(head==NULL) { head=p1; p2=p1; } else { p2->next=p1; p2=p1; } printf("please input pd:\n"); scanf("%d",&pd); pc++; } p2->next=NULL; return(head); } /*输入/添加记录*/ ID *insert(ID *head) { ID *temp,*p1,*p2; int pd; start: p1=head; printf("插入操作开始!!!\n"); temp=(ID *)malloc(sizeof(ID)); printf("请输入学生的学号:\n");scanf("%d",&temp->num); printf("请输入学生的姓名:\n");scanf("%s",temp->name); printf("请输入学生的年龄:\n");scanf("%d",&temp->age); printf("请输入学生的性别:\n");scanf("%s",temp->sex); printf("请输入学生的系别:\n");scanf("%s",temp->xi); printf("请输入学生的专业:\n");scanf("%s",temp->zhuan); printf("请输入学生的地址:\n");scanf("%s",temp->add); if (head==NULL) { head=temp; temp->next=NULL; } else { while(p1!=NULL) { p2=p1; p1=p1->next; } p2->next=temp; temp->next=NULL; } printf("插入末尾成功"); pc++; printf("是否继续插入 1.Yes 2.No;\n"); scanf("%d",&pd); if(pd==1) goto start; return (head); } /*删除学生记录*/ ID *delet(ID *head) { ID *p1,*p2; int num; printf("请输入要删除的学生的学号:");scanf("%d",&num); p1=head; if (head==NULL) { printf("没有记录\n"); goto end; } while(num!=p1->num && p1!=NULL) { p2=p1;p1=p1->next; } if(num==p1->num) { if (p1==head) head=p1->next; else p2->next=p1->next; printf("删除成功!!!\n"); pc--; //free(p1); //free(p2); } end:return head; } /*查找学生记录*/ ID *search(ID *head) { ID *p1,*p2; int num; printf("请输入要查找的学生的学号:");scanf("%d",&num); p1=head; while(num!=p1->num && p1!=NULL) { p2=p1;p1=p1->next; } if(num==p1->num) { printf("学生的学号:%d\n",p1->num); printf("学生的姓名:%s\n",p1->name); printf("学生的年龄:%d\n",p1->age); printf("学生的性别:%s\n",p1->sex); printf("学生的系别:%s\n",p1->xi); printf("学生的专业:%s\n",p1->zhuan); printf("学生的地址:%s\n",&p1->add); //free(p1); //free(p2); } return head; } /*按学号查询学生记录进行修改*/ ID *modify_num(ID *head) { ID *p; int i,m,n,num; start: printf("请输入要修改的学生的学号:"); scanf("%d",&num); p=head; while(p!=NULL ) { if(num==p->num) { m=1; while(m==1) { m=0; printf("\t\t 1.修改学生的学号\n"); printf("\t\t 2.修改学生的姓名\n"); printf("\t\t 3.修改学生的年龄\n"); printf("\t\t 4.修改学生的性别\n"); printf("\t\t 5.修改学生的系别\n"); printf("\t\t 6.修改学生的专业\n"); printf("\t\t 7.修改学生的地址\n"); printf("请选择(1--7):"); scanf("%d",&i); switch( i ) { case 1 : printf("请输入修改后的学号:"); scanf("%d",&p->num); break; case 2: printf("请输入修改后的姓名:"); scanf("%s",p->name); break; case 3: printf("请输入修改后的年龄:"); scanf("%d",&p->age); break; case 4: printf("请输入修改后的性别:"); scanf("%s",&p->sex); break; case 5: printf("请输入修改后的系别:"); scanf("%s",p->xi); break; case 6: printf("请输入修改后的专业:"); scanf("%s",p->zhuan); break; case 7: printf("请输入修改后的地址:"); scanf("%s",p->add); break; default: printf("输入错误,请重新输入"); } } break; } p=p->next; } printf("是否继续修改其他学生情况(1改 2不改):"); scanf("%d",&n); if(n==1)goto start; else return head; } /*退出程序*/ void ask_age() { if(pc==0) { printf("没有记录\n"); return ; } ave_age=float(sum_age*1.0/pc); printf("%f\n",ave_age); printf("%d\n",max_age); printf("%d\n",min_age); } /*显示结果函数*/ void print(ID *head) { ID *p; p=head; printf("\t\t\t*****************\n"); printf("显示结果是:\n"); if(head!=NULL) do { printf("%10d%10s%10d%10s%10s%10s%10s\n",p->num,p->name,p->age,p->sex,p->xi,p->zhuan,p->add); p=p->next; } while(p!=NULL); } void main() { ID *head; int choise; printf("\t\t\t* * * * 李林C语言课设* * * *\n"); while(1) { printf("\t\t 学生信息管理系统\n"); printf("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n"); printf("\t\t 1.建立文件\n"); printf("\t\t 2.插入数据\n"); printf("\t\t 3.删除数据\n"); printf("\t\t 4.修改记录\n"); printf("\t\t 5.搜索记录\n"); printf("\t\t 6.求年龄\n"); printf("\t\t 0.退出\n"); printf("\n"); printf("~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~\n"); printf("请选择(0-6):"); scanf("%d",&choise); switch(choise) { case 1: head=creat(); print(head); break; case 2: head=insert(head); print(head); break; case 3: head=delet(head); print(head); break; case 4: head=modify_num(head); print(head); break; case 5:search(head); print(head); break; case 6:ask_age(); break; case 0: exit(0); break; default :printf("输入错误,请重新输入!\n"); } } } ★★★★★★★★★★★★★★★★★★★★★★★★★★★ #include "stdio.h" #include "stdlib.h" #include "string.h" #include "conio.h" #include "stdlib.h" #define null 0 struct record { char name[20]; char phone[20]; char adress[40]; char postcode[10]; char e_mail[30]; }student[500]; struct LinkList { struct record US; struct LinkList *next; }a; struct LinkList *head=null; int num=0; FILE *fp; int menu_select(); int adduser(); int list(); int search(); int display(); int add(); int listbyname(); int dele(); int save(); int exit(); void main() { system("cls"); for(;;) { switch(menu_select()) { case 0:adduser();break; case 1:list();break; case 2:search();break; case 3:display();break; case 4:add();break; case 5:listbyname();break; case 6:dele();break; case 7:save();break; case 8:exit(0); } } } menu_select() { char s[80]; int a; printf("*_* press any key enter menu! *_* \n"); getch(); system("cls"); printf("\t\t********************MENU*********************\n\n"); printf("\t\t 0. 输入记录\n"); printf("\t\t 1. 显示记录 \n"); printf("\t\t 2. 按姓名查找\n"); printf("\t\t 3. 按电话号码查找\n"); printf("\t\t 4. 插入记录 \n"); printf("\t\t 5. 按姓名排序\n"); printf("\t\t 6. 删除记录\n"); printf("\t\t 7. 记录保存文件\n"); printf("\t\t 8. Quit\n"); printf("\t\t***********************************************\n"); do{ printf("\n Enter you choice(0~11):"); scanf("%s",s); a=atoi(s); } while (a11); return a; } adduser() { printf("\n\t\t**************** 请输入用户信息 ****************\n"); printf("\n\t\t输入姓名:"); scanf("%s",&student[num].name); printf("\n\t\t输入电话号码:"); scanf("%s",&student[num].phone); printf("\n\t\t输入地址:"); scanf("%s",&student[num].adress); printf("\n\t\t输入邮编:"); scanf("%s",&student[num].postcode); printf("\n\t\t输入e-mail:"); scanf("%s",&student[num].e_mail); num++; printf("\n\t\t是否继续添加?(Y/N):"); if (getch()=='y') adduser(); return(0); } list() { int i; system("cls"); if(num!=0) { printf("\n\t\t*************** 以下为通讯录所有信息************"); for (i=0;i<num;i++) { printf("\n\t\t姓名: %s",student[i].name); printf("\n\t\t电话: %s",student[i].phone); printf("\n\t\t地址: %s",student[i].adress); printf("\n\t\t邮编: %s",student[i].postcode); printf("\n\t\te-mail:%s",student[i].e_mail); printf("\t\t"); if (i+1<num) { printf("\n\t\t__________________________"); system("pause"); } } printf("\n\t\t************************************************"); } else printf("\n\t\t通讯录中无任何纪录"); printf("\n\t\t按任意键返回主菜单:"); getch(); return(0); } search() { int mark=0; int i; int a=0; printf("\n\t\t***************** 按姓名查找 *******************"); char name[20]; printf("\n\t\t请输入姓名:"); scanf("%s",name); for(i=a;i<num;i++) { if (strcmp(student[i].name,name)==0) { printf("\n\t\t************* 以下是您查找的用户信息 ***********"); printf("\n\t\t姓名: %s",student[i].name); printf("\n\t\t电话: %s",student[i].phone); printf("\n\t\t地址: %s",student[i].adress); printf("\n\t\te-mail:%s",student[i].e_mail); printf("\n\t\t************************************************"); mark++; if ((i+1)<num) { printf("\n\t\t是否继续查找相同名字的用户信息:(y/n)"); if (getch()=='y') { a=i; continue; } else return(0); } else { printf("\n\t\t按任意键返回主菜单"); getch(); return(0); } } } if(mark!=0) { printf("\n\t\t没有相同姓名的用户纪录"); printf("\n\t\t按任意键返回主菜单"); getch(); return(0); } else { printf("\n\t\t没有相同姓名的用户纪录"); printf("\n\t\t按任意键返回主菜单"); getch(); return(0); } } display() { int mark=0; int i; int a=0; printf("\n\t\t****************** 按电话查找 ******************"); char phone[10]; printf("\n\t\t请输入电话号码:"); scanf("%s",phone); for(i=0;i<num;i++) { if (strcmp(student[i].phone,phone)==0) { printf("\n\t\t************** 以下是您查找的用户信息 **********"); printf("\n\t\t姓名: %s",student[i].name); printf("\n\t\t电话: %s",student[i].phone); printf("\n\t\t地址: %s",student[i].adress); printf("\n\t\te-mail:%s",student[i].e_mail); printf("\n\t\t************************************************"); printf("\n\t\t按任意键返回主菜单:"); mark++; getch(); return(0); } } if (mark==0) { printf("\n\t\t没有改用户的信息"); printf("\n\t\t按任意键返回主菜单"); getch(); return(0); } return(0); } add() { int i; if ((fp=fopen("student.bin","wb"))==NULL) { printf("\n\t\t文件打开失败"); } for (i=0;i<num;i++) { if (fwrite(&student[i],sizeof(struct record),1,fp)!=1) { printf("\n\t\t写入文件错误!\n"); } printf("\n\t\t**************** 请输入用户信息 ****************\n"); printf("\n\t\t输入姓名:"); scanf("%s",&student[num].name); printf("\n\t\t输入电话号码:"); scanf("%s",&student[num].phone); printf("\n\t\t输入地址:"); scanf("%s",&student[num].adress); printf("\n\t\t输入邮编:"); scanf("%s",&student[num].postcode); printf("\n\t\t输入e-mail:"); scanf("%s",&student[num].e_mail); num++; printf("\n\t\t是否继续添加?(Y/N):"); if (getch()=='y') adduser(); return(0); } fclose(fp); printf("\n\t\t通讯录文件已保存"); printf("\n\t\t按任意键退出程序\n\t\t"); exit(0); return(0); } void deletebyphone() { int i,j; int deletemark=0; char phone[20]; printf("\n\t\t请输入要删除用户电话号码:"); scanf("%s",phone); if(num==0) { printf("\n\t\t对不起,文件中无任何纪录"); printf("\n\t\t按任意键返回主菜单"); getch(); return; } for (i=0;i<num;i++) { if (strcmp(student[i].phone,phone)==NULL) { printf("\n\t\t以下是您要删除的用户纪录:"); printf("\n\t\t姓名: %s",student[i].name); printf("\n\t\t电话: %s",student[i].phone); printf("\n\t\t地址: %s",student[i].adress); printf("\n\t\te-mail:%s",student[i].e_mail); printf("\n\t\t是否删除?(y/n)"); if (getch()=='y') { for (j=i;j<num-1;j++) student[j]=student[j+1]; num--; deletemark++; printf("\n\t\t删除成功"); printf("\n\t\t是否继续删除?(y/n)"); if (getch()=='y') deletebyphone(); return; } else return; } continue; } if (deletemark==0) { printf("\n\t\t没有该用户的纪录"); printf("\n\t\t是否继续删除?(y/n)"); if (getch()=='y') deletebyphone(); return; } } void deletebyname() { int a=0; int findmark=0; int j; int deletemark=0; int i; char name[20]; printf("\n\t\t请输入要删除用户姓名:"); scanf("%s",name); for (i=a;i<num;i++) { if (strcmp(student[i].name,name)==NULL) { printf("\n\t\t以下是您要删除的用户纪录:"); findmark++; printf("\n\t\t________________________________"); printf("\n\t\t姓名: %s",student[i].name); printf("\n\t\t电话: %s",student[i].phone); printf("\n\t\t地址: %s",student[i].adress); printf("\n\t\te-mail:%s",student[i].e_mail); printf("\n\t\t________________________________"); printf("\n\t\t是否删除?(y/n)"); if (getch()=='y') { for (j=i;j<num-1;j++) student[j]=student[j+1]; num--; deletemark++; printf("\n\t\t删除成功"); if((i+1)<num) { printf("\n\t\t是否继续删除相同姓名的用户信息?(y/n)"); if (getch()=='y') { a=i; continue; } } printf("\n\t\t是否继续删除?(y/n)"); if (getch()=='y') deletebyname(); return; } if((i+1)<num) { printf("\n\t\t是否继续删除相同姓名的用户信息?(y/n)"); if (getch()=='y') { a=i; continue; } } } else continue; } if ((deletemark==0)&&(findmark==0)) { printf("\n\t\t没有该用户的纪录"); printf("\n\t\t是否继续删除?(y/n)"); if (getch()=='y') deletebyphone(); return; return; } else if (findmark!=0) { printf("\n\t\t没有重名信息"); printf("\n\t\t没有该用户的纪录"); printf("\n\t\t是否继续删除?(y/n)"); if (getch()=='y') deletebyphone(); return; return; } } dele() { char choic; printf("\n\t\t1-按电话号码删除 2-按姓名删除"); printf("\n\t\t请选择:"); choic=getch(); switch (choic) { case '1':deletebyphone();break; case '2':deletebyname();break; } return(0); } listbyname() { int i,j; struct record tmp; for (i=1;i<num;i++) { if(strcmp(student[i].name,student[i-1].name)<0) { tmp=student[i]; j=i-1; do { student[j+1]=student[j]; j--; }while ((strcmp(tmp.name,student[j].name)=0)); student[j+1]=tmp; } } printf("\n\t\t排序成功,是否显示?(y/n)"); if (getch()=='y') list(); return(0); } save() { int j; FILE*fp; fp=fopen("student.txt","w"); if (fp==NULL) printf("can't open the file."); if(num!=0) { for(j=0;j<num;j++) { fwrite(student,sizeof(student),1,fp); } } printf("保存成功!"); fclose(fp); return(0); }

最新推荐

recommend-type

C语言实现银行管理系统

【C语言实现银行管理系统】是将银行的基本操作如存款、取款、查询、开户、销户、转账等集成到一个程序中,通过C语言编程来模拟真实的银行服务流程。这样的系统可以帮助学习者理解如何在实际场景中应用C语言,同时也...
recommend-type

C语言实现简单航班管理系统

C语言实现简单航班管理系统知识点大全 一、数据结构 * 结构体的使用:在本系统中,我们使用了两个结构体,分别是航班信息结构体(Plane)和乘客信息结构体(Person)。 * 结构体成员变量:我们在结构体中定义了多...
recommend-type

C语言实现餐饮结账管理系统

"C语言实现餐饮结账管理系统" 本文主要介绍了使用C语言实现的餐饮结账管理系统的设计和实现。该系统主要功能包括信息录入、修改、删除、台面号查询、服务生查询、金额排序、总收入和顾客总数等。 首先,系统使用了...
recommend-type

C语言图书管理系统简洁版

《C语言图书管理系统简洁版》是一个基于DOS界面的实用程序,它允许用户进行图书管理,包括管理员和会员两种角色的操作。系统的核心是用C语言实现的,它提供了丰富的功能来满足基本的图书管理和借阅需求。 首先,...
recommend-type

C语言编写教务管理系统

C语言编写教务管理系统 C语言编写教务管理系统是使用C语言编写的一个教务管理系统,旨在帮助学校管理学生的基本信息和课程成绩。该系统具有录入、修改、删除、查询和统计等功能,可以满足学校的日常教学管理需求。 ...
recommend-type

PHP集成Autoprefixer让CSS自动添加供应商前缀

标题和描述中提到的知识点主要包括:Autoprefixer、CSS预处理器、Node.js 应用程序、PHP 集成以及开源。 首先,让我们来详细解析 Autoprefixer。 Autoprefixer 是一个流行的 CSS 预处理器工具,它能够自动将 CSS3 属性添加浏览器特定的前缀。开发者在编写样式表时,不再需要手动添加如 -webkit-, -moz-, -ms- 等前缀,因为 Autoprefixer 能够根据各种浏览器的使用情况以及官方的浏览器版本兼容性数据来添加相应的前缀。这样可以大大减少开发和维护的工作量,并保证样式在不同浏览器中的一致性。 Autoprefixer 的核心功能是读取 CSS 并分析 CSS 规则,找到需要添加前缀的属性。它依赖于浏览器的兼容性数据,这一数据通常来源于 Can I Use 网站。开发者可以通过配置文件来指定哪些浏览器版本需要支持,Autoprefixer 就会自动添加这些浏览器的前缀。 接下来,我们看看 PHP 与 Node.js 应用程序的集成。 Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行时环境,它使得 JavaScript 可以在服务器端运行。Node.js 的主要特点是高性能、异步事件驱动的架构,这使得它非常适合处理高并发的网络应用,比如实时通讯应用和 Web 应用。 而 PHP 是一种广泛用于服务器端编程的脚本语言,它的优势在于简单易学,且与 HTML 集成度高,非常适合快速开发动态网站和网页应用。 在一些项目中,开发者可能会根据需求,希望把 Node.js 和 PHP 集成在一起使用。比如,可能使用 Node.js 处理某些实时或者异步任务,同时又依赖 PHP 来处理后端的业务逻辑。要实现这种集成,通常需要借助一些工具或者中间件来桥接两者之间的通信。 在这个标题中提到的 "autoprefixer-php",可能是一个 PHP 库或工具,它的作用是把 Autoprefixer 功能集成到 PHP 环境中,从而使得在使用 PHP 开发的 Node.js 应用程序时,能够利用 Autoprefixer 自动处理 CSS 前缀的功能。 关于开源,它指的是一个项目或软件的源代码是开放的,允许任何个人或组织查看、修改和分发原始代码。开源项目的好处在于社区可以一起参与项目的改进和维护,这样可以加速创新和解决问题的速度,也有助于提高软件的可靠性和安全性。开源项目通常遵循特定的开源许可证,比如 MIT 许可证、GNU 通用公共许可证等。 最后,我们看到提到的文件名称 "autoprefixer-php-master"。这个文件名表明,该压缩包可能包含一个 PHP 项目或库的主分支的源代码。"master" 通常是源代码管理系统(如 Git)中默认的主要分支名称,它代表项目的稳定版本或开发的主线。 综上所述,我们可以得知,这个 "autoprefixer-php" 工具允许开发者在 PHP 环境中使用 Node.js 的 Autoprefixer 功能,自动为 CSS 规则添加浏览器特定的前缀,从而使得开发者可以更专注于内容的编写而不必担心浏览器兼容性问题。
recommend-type

揭秘数字音频编码的奥秘:非均匀量化A律13折线的全面解析

# 摘要 数字音频编码技术是现代音频处理和传输的基础,本文首先介绍数字音频编码的基础知识,然后深入探讨非均匀量化技术,特别是A律压缩技术的原理与实现。通过A律13折线模型的理论分析和实际应用,本文阐述了其在保证音频信号质量的同时,如何有效地降低数据传输和存储需求。此外,本文还对A律13折线的优化策略和未来发展趋势进行了展望,包括误差控制、算法健壮性的提升,以及与新兴音频技术融合的可能性。 # 关键字 数字音频编码;非均匀量化;A律压缩;13折线模型;编码与解码;音频信号质量优化 参考资源链接:[模拟信号数字化:A律13折线非均匀量化解析](https://wenku.csdn.net/do
recommend-type

arduino PAJ7620U2

### Arduino PAJ7620U2 手势传感器 教程 #### 示例代码与连接方法 对于Arduino开发PAJ7620U2手势识别传感器而言,在Arduino IDE中的项目—加载库—库管理里找到Paj7620并下载安装,完成后能在示例里找到“Gesture PAJ7620”,其中含有两个示例脚本分别用于9种和15种手势检测[^1]。 关于连线部分,仅需连接四根线至Arduino UNO开发板上的对应位置即可实现基本功能。具体来说,这四条线路分别为电源正极(VCC),接地(GND),串行时钟(SCL)以及串行数据(SDA)[^1]。 以下是基于上述描述的一个简单实例程序展示如
recommend-type

网站啄木鸟:深入分析SQL注入工具的效率与限制

网站啄木鸟是一个指的是一类可以自动扫描网站漏洞的软件工具。在这个文件提供的描述中,提到了网站啄木鸟在发现注入漏洞方面的功能,特别是在SQL注入方面。SQL注入是一种常见的攻击技术,攻击者通过在Web表单输入或直接在URL中输入恶意的SQL语句,来欺骗服务器执行非法的SQL命令。其主要目的是绕过认证,获取未授权的数据库访问权限,或者操纵数据库中的数据。 在这个文件中,所描述的网站啄木鸟工具在进行SQL注入攻击时,构造的攻击载荷是十分基础的,例如 "and 1=1--" 和 "and 1>1--" 等。这说明它的攻击能力可能相对有限。"and 1=1--" 是一个典型的SQL注入载荷示例,通过在查询语句的末尾添加这个表达式,如果服务器没有对SQL注入攻击进行适当的防护,这个表达式将导致查询返回真值,从而使得原本条件为假的查询条件变为真,攻击者便可以绕过安全检查。类似地,"and 1>1--" 则会检查其后的语句是否为假,如果查询条件为假,则后面的SQL代码执行时会被忽略,从而达到注入的目的。 描述中还提到网站啄木鸟在发现漏洞后,利用查询MS-sql和Oracle的user table来获取用户表名的能力不强。这表明该工具可能无法有效地探测数据库的结构信息或敏感数据,从而对数据库进行进一步的攻击。 关于实际测试结果的描述中,列出了8个不同的URL,它们是针对几个不同的Web应用漏洞扫描工具(Sqlmap、网站啄木鸟、SqliX)进行测试的结果。这些结果表明,针对提供的URL,Sqlmap和SqliX能够发现注入漏洞,而网站啄木鸟在多数情况下无法识别漏洞,这可能意味着它在漏洞检测的准确性和深度上不如其他工具。例如,Sqlmap在针对 "http://www.2cto.com/news.php?id=92" 和 "http://www.2cto.com/article.asp?ID=102&title=Fast food marketing for children is on the rise" 的URL上均能发现SQL注入漏洞,而网站啄木鸟则没有成功。这可能意味着网站啄木鸟的检测逻辑较为简单,对复杂或隐蔽的注入漏洞识别能力不足。 从这个描述中,我们也可以了解到,在Web安全测试中,工具的多样性选择是十分重要的。不同的安全工具可能对不同的漏洞和环境有不同的探测能力,因此在实际的漏洞扫描过程中,安全测试人员需要选择合适的工具组合,以尽可能地全面地检测出应用中存在的漏洞。 在标签中指明了这是关于“sql注入”的知识,这表明了文件主题的核心所在。SQL注入是一种常见的网络攻击方式,安全测试人员、开发人员和网络管理员都需要对此有所了解,以便进行有效的防御和检测。 最后,提到了压缩包子文件的文件名称列表,其中包含了三个文件:setup.exe、MD5.exe、说明_Readme.html。这里提供的信息有限,但可以推断setup.exe可能是一个安装程序,MD5.exe可能是一个计算文件MD5散列值的工具,而说明_Readme.html通常包含的是软件的使用说明或者版本信息等。这些文件名暗示了在进行网站安全测试时,可能涉及到安装相关的软件工具,以及进行文件的校验和阅读相应的使用说明。然而,这些内容与文件主要描述的web安全漏洞检测主题不是直接相关的。
recommend-type

【GPStoolbox使用技巧大全】:20个实用技巧助你精通GPS数据处理

# 摘要 GPStoolbox是一个广泛应用于GPS数据处理的软件工具箱,它提供了从数据导入、预处理、基本分析到高级应用和自动化脚本编写的全套功能。本文介绍了GPStoolbox的基本概况、安装流程以及核心功能,探讨了如何