c语言数据操作实例

#include<stdio.h>

//学生结构体
struct student{
    int num;
    char name[20];
};
const int max_num = 40;
struct student stu[max_num];

int now_num = 0;

//添加学生信息
void insert()
{
    if(now_num == 40){
        printf("本系统已经到达最大容量\n");
        return;
    }
    int i=0,m,k;
flag2:
    printf("当前已有%d个学生信息存在本系统当中,您还可增加%d个学生信息\n",now_num,40-now_num);
    printf("请输入待增加的学生数:");
    scanf("%d",&m);
    if(m>40-now_num){
        printf("此数字超过本系统能容纳的最大数量,请重新填写数字\n");
        goto flag2;
    }
    now_num = now_num+m;
    if(m>0)
    {
        flag3:
        while(i+1<=m){
            for(k=0;k<=39;k++)
            {
                if(stu[k].num == 0){
                    printf("请输入第%d位学生的学号:",k+1);
                    scanf("%d",&stu[k].num);
                    printf("请输入第%d位学生的姓名:",k+1);
                    scanf("%s",&stu[k].name);
                    i+=1;
                    goto flag3;
                }
            }
        }
        printf("学生信息增加完毕!!!\n");
    }else{
        printf("输入待添加的学生数为0,自动退出。");
    }
};


//展示学生信息(遍历)
void show_all(){
    int i=0;
    while(stu[i].num != 0){
        printf("学号:%d,姓名:%s\n", stu[i].num, stu[i].name);
        i += 1;
    };
};

//查找单个学生信息
void search_one(){
    int j,i;
    printf("请输入你想查询的学生学号:");
    scanf("%d",&j);
    for(i=0;i<=39;i++){
        if(stu[i].num == j){
            printf("这位学生的学号为:%d,姓名为:%s,对应的下标为:%d\n",stu[i].num,stu[i].name,i);
            break;
        }
    }
    printf("-1\n");
}

void search_x(){
    int want_x,i;
    int y = -1;
    printf("请输入你想查找的“x”:");
    scanf("%d",&want_x);
    for(i=0;i<=39;i++)//这个length可以通过全局变量 也可以改成从参数传过来
    {
        if(stu[i].num == want_x) break;
    }
    if(i == 40){
        printf("-1\n");
    }else{
        printf("您输入的这个值对应在结构体的下标为%d\n",i);
    }
}

//删除单个学生信息
void delete_one(){
    int delete_num = 0,i,j,k;
    printf("请输入想要删除的学生学号:");
    scanf("%d",&delete_num);
    for(i=0;i<=39;i++)
    {
        if(stu[i].num == delete_num){
            k = i; //保留学生所对应的下标
            for(j=i+1;j<=39;j++){
                stu[i] = stu[j];
                i++;
            }
            printf("该学生的下标为:%d,删除成功!!!\n",k);
            break;
        }
    }
    printf("-1\n");
}

//插入单个学生信息
void insert_one(){
    int i,j,p;
    printf("请输入要插入学生信息的下标:");
    scanf("%d",&i);
    for(j=i+1;j<=39;j++)
    {
        if(stu[j].num == 0) break;
    }
    for(p=i;p<=j;p++){
        stu[j] = stu[j-1];
        j--;
    }
    printf("请输入学生学号:");
    scanf("%d",&stu[i].num);
    printf("请输入学生姓名:");
    scanf("%s",&stu[i].name);
    now_num++;
}

//主函数
int main()
{
    int a;
    for(a=0;a<=39;a++){
        stu[a]={0,0};
        a++;
    }
flag1:
    int i;
    printf("欢迎使用系统!\n");
    printf("1.添加学生信息\n");
    printf("2.读取已有的所有学生信息\n");
    printf("3.删除学生信息\n");
    printf("4.查找单个学生信息\n");
    printf("5.查找值为x的学生对应的下标\n");
    printf("6.插入单个学生信息\n");
    printf("7.退出服务\n");
    printf("请输入你的服务:");
    scanf("%d",&i);
    switch(i){

        case 1:
            insert();
            goto flag1;
        case 2:
            show_all();
            goto flag1;
        case 3:
            delete_one();
            goto flag1;
        case 4:
            search_one();
            goto flag1;
        case 5:
            search_x();
            goto flag1;
        case 6:
            insert_one();
            goto flag1;
        case 7:
            printf("感谢您对本系统的使用");
            break;
        default:
            printf("无该对应选项,请重新输入。");
            goto flag1;
    }
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值