求大佬给个思路
各位大佬,初学这个,看到下面这个程序,不知道怎么办,能不能给个思路,不会用链表。。。自动寄存柜
某超市门口的自动寄存柜有n个寄存箱,并且有一个投币控制器,顾客想要寄存小件物品时,只要在投币控制器中投入一个1元硬币,如果此时有空闲的箱子,寄存柜就会自动打开一个空的箱子,并且打印输出一张小小的密码纸条;如果没有空闲的箱子,则提示“本柜已满”。当顾客离开超市时,用密码纸条上指定的数字密码依次输入到开箱控制器,则顾客所存包的箱子门就会自动打开,顾客取走物品后,关上门。
输入数据时,可先输入寄存箱总数n, 再由用户选择是“投硬币”还是“输密码”。
如果选择“投硬币”,则只有硬币值是1时才开箱。如果有空闲的箱子,则输出箱子编号及密码(4位数字); 如果无空闲的箱子,则提示“本柜已满”。
如果选择“输密码”,若输入的密码与某一箱子密码相符,则显示打开的箱子编号,否则输出提示“密码错误”。
万能密码:假定有一个密码000086,该密码用于营业结束后整理寄存柜。先在菜单中输入隐藏的选项5,然后提示请输入万能密码,密码输入后,打开所有的箱子,如有箱子中客户没有取走东西,则提示:请重点检查某编号的箱子是否有物留存。
请编写开箱控制程序实现上述过程。
输入输出示例:
寄存箱总数:10
1.投硬币2.输密码0.退出 请选择:1
投币值:1
寄存箱编号:1密码:9342
1.投硬币2.输密码0.退出 请选择:2
输入密码:9342
1号寄存箱已打开
1.投硬币2.输密码0.退出 请选择:5
请输入万能密码:000086
箱子已经全部打开,请重点检查编号1,编号7的箱子是否有物留存
1.投硬币2.输密码0.退出 请选择:0
结束
感觉可以用数组来解决:A,A 设置是否空闲,满 = 1,闲 = 0;A 设置个人密码;A 设置万能密码。
然后,调用子函数分别来解决投硬币、输密码及退出。
先看看大佬们的,我要去上班,晚上回来,试写一下,看这个方案行还是不行 初学就写这么长的东西。。。
我们来想想超市货物柜
首先上面有按键。和键盘一样,按下某某键,会有一个值过去。我们用键盘模拟
就用1,2,0,5来表示当时按键返回的不同键值吧
那么:一开始就有一个输入接收器等着,分别接收1,2,0,5。若是其它值则没有反应
可以分别为1,2,0,5设计相应的函数。也可以直接一体全在main中实现。看你自己了
另外,要有个显示函数,用来显示当前情况。这个显示函数根据不同的值来显示不同的页面
输入寄存时,先检查箱子是否已满
而根据超市货柜来看,应该是满了就直接显示已满,再输入寄件就没反应或者提示别的。所以一开始也可以直接检查。这是个循环,因为一直在运行。先检查是否已满,再决定要接收哪几个键。也可以在寄件那个键的函数里选择,根据是否已满进行不同的操作和显示
输密码的键接收后调取输密码函数
其他也一样。
投币可以进行选择或比较。不是1统统无效
除了干这事,还需要一个函数或者变量,来记哪几个箱子被使用了。可以用数组来记。使用与否值不一样,因此只需要一位来记。bool变量正好。万能钥匙使用时,检查这些编号是否使用中,是就显示某些东西,不是就不显示。
有人输密码取件后,相应编号的变量值变更为未使用。 405794672 发表于 2020-8-23 14:14
初学就写这么长的东西。。。
我们来想想超市货物柜
首先上面有按键。和键盘一样,按下某某键,会有一个值 ...
谢谢大佬啦,弄出来了 风过无痕1989 发表于 2020-8-23 13:49
感觉可以用数组来解决:A,A 设置是否空闲,满 = 1,闲 = 0;A 设置个人密码;A 设置万能 ...
谢谢大佬啦,我弄了一下午弄出来了 本帖最后由 Cool_Breeze 于 2020-8-24 15:28 编辑
# 当练习题做了/*
# 还有许多功能没有写!
# BY Cool_Breeze
# 2020/08/24
# GCC .c
*/
#include<stdio.h>
#include<malloc.h>
typedef unsigned char uchar;
typedef unsigned int uint;
#define N 10 // 格子数量
uchar ABLE = 0; //可用箱子数量
typedef struct GRID
{
uchar id;
uchar status;
uint password;
struct GRID* next;
}GRIDV,*GRIDP;
// 初始化储物柜格子
GRIDP __init__(void);
// 打印格子信息
// check = 1 只打印可用数量
// check = 2 打印格子信息和可用数量
// check = 0 检查可用格子数量
void print_grid(GRIDP grid, uchar check);
// 操作菜单
uchar operation_menu(GRIDP head);
// 存物品
void store_items(GRIDP);
// 取物品
uchar get_items(GRIDP head, int* passwd);
// 管理员
void adminstrator(GRIDP grid);
int main(void)
{
//system("chcp 936");
GRIDP locker = __init__();
print_grid(locker, 1);
operation_menu(locker);
return 0;
}
GRIDP __init__(void)
{
uchar i = 0;
GRIDP head, cnter, grid;
for (; i<N; i++)
{
grid = (GRIDP)malloc(sizeof(GRIDV));
if (i == 0)
{
head = cnter = grid;
grid->id = i + 1;
grid->status = 0;
grid->password = 0;
grid->next = NULL;
}
else
{
cnter->next = grid;
grid->id = i + 1;
grid->status = 0;
grid->password = 0;
grid->next = NULL;
cnter = grid;
}
}
return head;
}
void print_grid(GRIDP grid, uchar check)
{
ABLE = 0;
uchar i = 0;
for (; i<N; i++)
{
if (grid->status == 0) ABLE++;
if (check == 2)
printf("格子号:%d\t物品状态:%d\n", grid->id, grid->status);
grid = grid->next;
}
if (check) printf("可用格子数量为:%d\n", ABLE);
}
uchar operation_menu(GRIDP head)
{
uchar i = 0;
uchar number = 0;
uchar ad_passwd = {0};
uchar ad_pd_ok = {'0','0','0','0','8','6'}; // 管理员密码
uint passwd = {0};
while (1)
{
printf("\n1. 投硬币\t2. 取走物品\t3.查询可用格子数量\t0. 退出\n请选择:");
scanf("%d", &number);
getchar();
switch (number)
{
case 1:
print_grid(head, 0);
if (!ABLE)
{
printf("储物柜已满!\n");
break;
}
else
{
store_items(head);
break;
}
case 2:
while (1)
{
*passwd = 0;
*(passwd+1) = 0;
printf("请输入格子号:");
scanf("%d", passwd);
getchar();
printf("请输入密码:");
scanf("%d", passwd+1);
getchar();
if (get_items(head, passwd))
{
printf("输入密码或者格子号错误!请重新选择\n");
break;
}
break;
}
break;
case 3:
print_grid(head, 1);
break;
case 5:
printf("请输入管理员密码:");
scanf("%s", ad_passwd);
getchar();
for (i=0; i<6; i++)
{
if (*(ad_passwd + i ) == *(ad_pd_ok + i ))
continue;
else
{
printf("管理员密码错误!请重新选择\n");
break;
}
}
if (i == 6)
{
adminstrator(head);
break;
}
break;
case 0:
return 0;
}
}
return 0;
}
void store_items(GRIDP grid)
{
// 密码就不写了
uchar i = 0;
for (; i<N; i++)
{
if (grid->status == 0)
{
grid->status = 1;
grid->password = 9342;
printf("格子号:%d\t密码:%d\n", grid->id, 9342);
break;
}
grid = grid->next;
}
}
uchar get_items(GRIDP grid, int* passwd)
{
uchar i = 0;
for (; i<N; i++)
{
if (grid->id == *passwd && grid->password == *(passwd+1))
{
grid->status = 0;
printf("格子号:%d 已打开\n", grid->id);
return 0;
}
grid = grid->next;
}
return 1;
}
void adminstrator(GRIDP grid)
{
GRIDP head = grid;
uchar i = 0;
for (; i<N; i++)
{
if (grid->status)
{
printf("请检查格子号:%d 是否存在物品\n", grid->id);
}
grid = grid->next;
}
printf("储物柜格子已经全部打开!\n");
// 默认管理员会清空全部格子
grid = head;
for (i=0; i<N; i++)
{
grid->status = 0;
grid = grid->next;
}
} Cool_Breeze 发表于 2020-8-24 14:57
# 当练习题做了
辛苦大佬了,感谢感谢 Cool_Breeze 发表于 2020-8-24 14:57
# 当练习题做了
后来做出来了,只不过方法没有你的高端{:5_96:} Christopher. 发表于 2020-8-26 20:09
后来做出来了,只不过方法没有你的高端
慢慢来,积少成多,熟能生巧!
页:
[1]