| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 980 人关注过本帖
标题:在编写完一个模拟的银行排号系统后出现了闪退和无法接收系统内账号密码的问 ...
只看楼主 加入收藏
Mr兔子
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2018-12-9
收藏
 问题点数:0 回复次数:0 
在编写完一个模拟的银行排号系统后出现了闪退和无法接收系统内账号密码的问题,请帮忙指点一下
在运行代码时候选择菜单选项1(图1)进入到子菜单里面(图2)的内容后选择1选项时到输入密码项会一直收集键盘动作(图3),如果选2的话会闪退
图片附件: 游客没有浏览图片的权限,请 登录注册
图片附件: 游客没有浏览图片的权限,请 登录注册
图片附件: 游客没有浏览图片的权限,请 登录注册

完整的代码如下:(谢谢)
程序代码:
#include<stdio.h>
#include<malloc.h>
#include<stdlib.h>
#include<conio.h>
#include<time.h>
#define n 3
int vip1=0;
int y,z;
float sum1=0,sum2=0,sum3=0,sum4=0,sum5=0;
float i1=0,i2=0,i3=0,i4=0,i5=0;
float ave1=0,ave2=0,ave3=0,ave4=0,ave5=0;
static int N;
struct List{
    int A[n+1];  //顾客用来办理业务的N个窗口
    int len;  //表示数组中的元素个数
}L;
struct Lnode{  //链表结点类型
    int data;
    Lnode *next;
};
struct Linkqueue{  //链式存储的等候队列的类型定义
    Lnode *front;
    Lnode *rear;
}Q;
void Initshuzu(){  //初始化线性表的算法
    for(int i=1;i<=n;i++)
        L.A[i]=0;  //元素值为0,表示编号为i的窗口当前状态为空
    L.len=0;
}
void Initqueue(){  //初始化队列的算法
    Q.front=Q.rear=(Lnode *)malloc(sizeof(Lnode));
    Q.front->next=NULL;
}
void Enqueue(Linkqueue *Q,int elem){  //进队算法
    Lnode *s;
    s=(Lnode *)malloc(sizeof(Lnode));
    s->data=elem;
    s->next=NULL;
    Q->rear->next=s;
    Q->rear=s;
}
int Dlqueue(Linkqueue *Q){  //出队算法
    Lnode *t;
    int x;
    if(Q->front==Q->rear){
        printf("队列为空!\n");
    }
    else{
        t=Q->front->next;
        Q->front->next=t->next;
        x=t->data;
        free(t);
        return x;
    }
}
void print1(){  //输出数组算法
    int i;
    printf("正在办理业务的客户编号为:\n");
    for( i=1;i<=L.len;i++){
        printf("%d ",L.A[i]);
    }
    printf("\n");
}
void print2(){  //输出队列算法
    int i=0;
    printf("正在等候办理业务的客户编号为:");
    Lnode *s=Q.front->next;
    while(s!=NULL){
        printf("%d ",s->data);
        s=s->next;
        i++;
    }
    printf("\n您的前面一共有%d人在排队,请您稍后!",i);
    printf("\n");
}
void daoda(int x){  //解决客户到达事件算法
    int i=L.len+1;
    if (L.len<n){
        L.A[i]=x;
        i++;
        L.len++;
    }
    else
        Enqueue(&Q,x);
}
void likai(int x){  //解决客户离开事件算法
    int i=0;
    do{
        if(x>L.len){
            printf("输入有误!\n请重新输入:");
            scanf("%d",&x);
        }else
            for(i=0;i<=L.len;i++){
                if(i==x){
                    printf("尊敬的%d号客户您好!\n",x);
                    L.A[i]=0;
                    L.len--;
                    if(Q.front!=Q.rear){
                        int y=Dlqueue(&Q);
                        L.A[i]=y;
                        L.len++;
                    }
                }
            }
    }while(i==0);
}
int guitai(){  //判断输入的柜台号是否正确
    int y=0;
    printf("请输入你所办理业务的柜台号(1-3):\n");
    scanf("%d",&y);
    if(y<1||y>5){
        printf("你输入的柜台号有误,请重新输入!\n");
        printf("请输入你所办理业务的柜台号(1-3):\n");
        scanf("%d",&y);
    }else
        printf("你所办理业务的柜台为%d.\n",y);
    return y;
}
int pingfen(){  //判断输入的分数是否正确
    int y=0;
    printf("请输入你的评分(1-5):\n  1分·········非常不满意;\n");
    printf("2分·········比较不满意;\n");
    printf("3分·········一般满意;\n");
    printf("4分·········比较满意;\n");
    printf("5分·········非常满意。\n");
    printf("请输入:");
    scanf("%d",&y);
    if(y<1||y>5){
        printf("你输入的评分有误,请重新输入!\n");
        printf("请输入你的评分(1-5):\n");
        scanf("%d",&y);
    }else
        printf("你的评分为%d.\n",y);
    return y;
}
void mygrade(){  //主评分函数
    printf("为了改善服务质量,请你对我们的服务进行评价。谢谢!\n");
    z=guitai();
    y=pingfen();
    switch (z){  //柜台评分处理
    case 1:{  //1号柜台评分处理
        sum1+=y;
        i1++;
        ave1=sum1/i1;
        printf("%d号柜台的平均满意度为%0.2f。感谢您的评分,谢谢!!!\n",z,ave1);
        break;
           }
    case 2:{  //2号柜台评分处理
        sum2+=y;
        i2++;
        ave2=sum2/i2;
        printf("%d号柜台的平均满意度为%0.2f。感谢您的评分,谢谢!!!\n",z,ave2);
        break;
           }
    case 3:{  //3号柜台评分处理
        sum3+=y;
        i3++;
        ave3=sum3/i3;
        printf("%d号柜台的平均满意度为%0.2f。感谢您的评分,谢谢!!!\n",z,ave3);
        break;
           }
    case 4:{  //4号柜台评分处理
        sum4+=y;
        i4++;
        ave4=sum4/i4;
        printf("%d号柜台的平均满意度为%0.2f。感谢您的评分,谢谢!!!\n",z,ave4);
        break;
           }
    case 5:{  //5号柜台评分处理
        sum5+=y;
        i5++;
        ave5=sum5/i5;
        printf("%d号柜台的平均满意度为%0.2f。感谢您的评分,谢谢!!!\n",z,ave5);
        break;
           }
    default : printf("你的输入有误,请重新输入!\n");
    }
    getch();
}
void vip(int x){  //vip用户认证
    int i,a;
    a=x;
    char ch[3];
    int k=0;
    switch(a){
    case 1:{
        printf("请输入您的卡号:");
        scanf("%d",&i);
        printf("请您输入五位密码:");
        while(ch[k-1]!=' '){
            ch[k]=getch();
            k++;
            printf("*");
        }
        if(i==100&&ch[0]=='1'&&ch[1]=='1'&&ch[2]=='1'&&ch[3]=='1'){
            printf("\n尊敬的VIP客户您好,请您直接到VIP区办理业务!\n");
            vip1++;
        }else
            if(i==200&&ch[0]=='2'&&ch[1]=='2'&&ch[2]=='2'&&ch[3]=='2'){
            printf("\n尊敬的VIP客户您好,请您直接到VIP区办理业务!\n");
            vip1++;
        }else
            if(i==300&&ch[0]=='3'&&ch[1]=='3'&&ch[2]=='3'&&ch[3]=='3'){
            printf("\n尊敬的VIP客户您好,请您直接到VIP区办理业务!\n");
            vip1++;
        }else
            if(i==400&&ch[0]=='4'&&ch[1]=='4'&&ch[2]=='4'&&ch[3]=='4'){
            printf("\n尊敬的VIP客户您好,请您直接到VIP区办理业务!\n");
            vip1++;
        }else
            if(i==500&&ch[0]=='5'&&ch[1]=='5'&&ch[2]=='5'&&ch[3]=='5'){
            printf("\n尊敬的VIP客户您好,请您直接到VIP区办理业务!\n");
            vip1++;
        }else
            printf("\n您的输入有误!\n");
        break;
           }
    default : break;
    }
}
void time(){  //时间函数
    time_t timep;
    time (&timep);
    printf("                   现在时刻:%s",ctime(&timep));
}
void main(){  //主函数
    time_t  a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,start,end;
    float  b1=0,b2=0,b3=0,b4=0,b5=0,b6=0,b7=0,b8=0,b9=0,b10=0,allsum=0,average=0,xi=0;
    float A[10]={0,0,0,0,0,0,0,0,0,0};
    int c,x,v=0,w=0;
    Initshuzu();
    Initqueue();
    double sum=0;
    while(1){
        printf("\n******************************欢迎光临郑州工商学院模拟银行******************************\n");
            printf("\n                   1      客户到达\n");
            printf("                   2      客户离开\n");
            printf("                   3      查看业务办理\n");
            printf("                   4      查看排队情况\n");
            printf("                   5      退出\n\n");
        printf("******************************欢迎光临郑州工商学院模拟银行******************************\n\n");
        time();
    
        printf("请输入:");
            scanf("%d",&c);
                switch(c)
            {
                case 1:
                    {
                        system("cls");
                        printf("\n******************************客户到达界面******************************\n\n");
                        int k=0;
                        int a;
                        printf("请选择你的客户类型:VIP客户请按1\n                    普通卡客户请按2\n");
                        printf("请输入:");
                        scanf("%d",&a);
                        if (a==1){
                            vip(a);
                            getch();
                        }
                        else{
                            v++;
                            printf("尊敬的普通卡客户,您的业务号为%d.\n",v);
                            daoda(v);
                        }
                        system("cls");
                        break;
                    }
                case 2:
                    {
                        system("cls");
                        printf("\n******************************客户离开界面******************************\n\n");
                        printf("请输入离开客户的编号:\n");
                        scanf("%d",&x);
                        likai(x);
                        mygrade();
                        w++;
                        allsum+=A[0];
                        getch();
                        system("cls");
                        break;
                    }
                case 3:
                    {
                        system("cls");
                        printf("\n******************************业务查询界面******************************\n\n");
                        print1();
                            getch();
                            system("cls");
                            break;
                    }
                case 4:
                    {
                        system("cls");
                        printf("\n******************************排队查询界面******************************\n\n");
                        print2();
                        getch();
                        system("cls");
                        break;
                    }
                case 5:
                    return;
                    getch();
                    system("cls");
                case 6:
                    {
                        system("cls");
                        printf("\n******************************系统查询界面******************************\n\n");
                        char cool[3];
                        int i=0,k=0;
                        printf("请输入您的卡号:");
                        scanf("%d",&i);
                        printf("请您输入五位密码:");
                        while(cool[k-1]!=' '){
                            cool[k]=getch();
                            k++;
                            printf("*");
                        }
                        if(i=000&&cool[0]=='1'&&cool[2]=='1'&&cool[3]=='1'){
                            average=allsum/w;
                            printf("\n目前已经有 %d 位普通客户,%d 位VIP客户成功办理业务!",w,vip1);
                            printf("\n普通客户业务办理总共用时 %0.2f,平均用时 %0.2f\n",allsum,average);
                        }
                        getch();
                        system("cls");
                        break;
                    }
                default:
                    printf("输入有误!请重新输入:\n");
                    getch();
                    system("cls");
            }
    }
    }
搜索更多相关主题的帖子: 输入 int 业务 printf 客户 
2018-12-09 15:29
快速回复:在编写完一个模拟的银行排号系统后出现了闪退和无法接收系统内账号密码 ...
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.024681 second(s), 11 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved