鱼C论坛

 找回密码
 立即注册
查看: 1312|回复: 8

[已解决]求大佬给个思路

[复制链接]
发表于 2020-8-23 13:04:15 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
各位大佬,初学这个,看到下面这个程序,不知道怎么办,能不能给个思路,不会用链表。。。



自动寄存柜

    某超市门口的自动寄存柜有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
    结束


最佳答案
2020-8-24 14:57:40
本帖最后由 Cool_Breeze 于 2020-8-24 15:28 编辑

# 当练习题做了
  1. /*
  2. # 还有许多功能没有写!
  3. # BY Cool_Breeze
  4. # 2020/08/24
  5. # GCC .c
  6. */

  7. #include<stdio.h>
  8. #include<malloc.h>


  9. typedef unsigned char uchar;
  10. typedef unsigned int uint;

  11. #define N 10 // 格子数量
  12. uchar ABLE = 0; //可用箱子数量


  13. typedef struct GRID
  14. {
  15.     uchar id;
  16.     uchar status;
  17.     uint password;
  18.     struct GRID* next;
  19. }GRIDV,*GRIDP;

  20. // 初始化储物柜格子
  21. GRIDP __init__(void);

  22. // 打印格子信息
  23. // check = 1 只打印可用数量
  24. // check = 2 打印格子信息和可用数量
  25. // check = 0 检查可用格子数量
  26. void print_grid(GRIDP grid, uchar check);

  27. // 操作菜单
  28. uchar operation_menu(GRIDP head);

  29. // 存物品
  30. void store_items(GRIDP);

  31. // 取物品
  32. uchar get_items(GRIDP head, int* passwd);

  33. // 管理员
  34. void adminstrator(GRIDP grid);

  35. int main(void)
  36. {
  37.     //system("chcp 936");
  38.     GRIDP locker = __init__();
  39.     print_grid(locker, 1);
  40.     operation_menu(locker);
  41.    
  42.     return 0;
  43. }

  44. GRIDP __init__(void)
  45. {
  46.     uchar i = 0;
  47.     GRIDP head, cnter, grid;
  48.    
  49.     for (; i<N; i++)
  50.     {
  51.         grid = (GRIDP)malloc(sizeof(GRIDV));
  52.         if (i == 0)
  53.         {
  54.             head = cnter = grid;
  55.             grid->id = i + 1;
  56.             grid->status = 0;
  57.             grid->password = 0;
  58.             grid->next = NULL;
  59.         }
  60.         else
  61.         {
  62.             cnter->next = grid;
  63.             grid->id = i + 1;
  64.             grid->status = 0;
  65.             grid->password = 0;
  66.             grid->next = NULL;
  67.             cnter = grid;
  68.         }
  69.     }
  70.    
  71.     return head;
  72. }

  73. void print_grid(GRIDP grid, uchar check)
  74. {
  75.     ABLE = 0;
  76.     uchar i = 0;
  77.     for (; i<N; i++)
  78.     {
  79.         if (grid->status == 0) ABLE++;
  80.         if (check == 2)
  81.             printf("格子号:%d\t物品状态:%d\n", grid->id, grid->status);
  82.         grid = grid->next;
  83.     }
  84.     if (check) printf("可用格子数量为:%d\n", ABLE);
  85. }

  86. uchar operation_menu(GRIDP head)
  87. {
  88.     uchar i = 0;
  89.     uchar number = 0;
  90.     uchar ad_passwd[6] = {0};
  91.     uchar ad_pd_ok[6] = {'0','0','0','0','8','6'}; // 管理员密码
  92.     uint passwd[2] = {0};
  93.     while (1)
  94.     {
  95.         printf("\n1. 投硬币\t2. 取走物品\t3.查询可用格子数量\t0. 退出\n请选择:");
  96.         scanf("%d", &number);
  97.         getchar();
  98.         switch (number)
  99.         {
  100.             case 1:
  101.                 print_grid(head, 0);
  102.                 if (!ABLE)
  103.                 {
  104.                     printf("储物柜已满!\n");
  105.                     break;
  106.                 }
  107.                 else
  108.                 {
  109.                     store_items(head);
  110.                     break;
  111.                 }
  112.             case 2:
  113.                 while (1)
  114.                 {
  115.                     *passwd = 0;
  116.                     *(passwd+1) = 0;
  117.                     printf("请输入格子号:");
  118.                     scanf("%d", passwd);
  119.                     getchar();
  120.                     printf("请输入密码:");
  121.                     scanf("%d", passwd+1);
  122.                     getchar();
  123.                     if (get_items(head, passwd))
  124.                     {
  125.                         printf("输入密码或者格子号错误!请重新选择\n");
  126.                         break;
  127.                     }
  128.                     break;   
  129.                 }
  130.                 break;
  131.             case 3:
  132.                 print_grid(head, 1);
  133.                 break;
  134.             case 5:
  135.                 printf("请输入管理员密码:");
  136.                 scanf("%s", ad_passwd);
  137.                 getchar();
  138.                 for (i=0; i<6; i++)
  139.                 {
  140.                     if (*(ad_passwd + i ) == *(ad_pd_ok + i ))
  141.                         continue;
  142.                     else
  143.                     {
  144.                         printf("管理员密码错误!请重新选择\n");
  145.                         break;
  146.                     }
  147.                 }
  148.                 if (i == 6)
  149.                 {
  150.                     adminstrator(head);
  151.                     break;
  152.                 }
  153.                 break;
  154.             case 0:
  155.                 return 0;
  156.         }
  157.     }
  158.     return 0;
  159. }

  160. void store_items(GRIDP grid)
  161. {
  162.     // 密码就不写了
  163.     uchar i = 0;
  164.     for (; i<N; i++)
  165.     {
  166.         if (grid->status == 0)
  167.         {
  168.             grid->status = 1;
  169.             grid->password = 9342;
  170.             printf("格子号:%d\t密码:%d\n", grid->id, 9342);
  171.             break;
  172.         }
  173.         grid = grid->next;
  174.     }
  175. }

  176. uchar get_items(GRIDP grid, int* passwd)
  177. {
  178.     uchar i = 0;
  179.     for (; i<N; i++)
  180.     {
  181.         if (grid->id == *passwd && grid->password == *(passwd+1))
  182.         {
  183.             grid->status = 0;
  184.             printf("格子号:%d 已打开\n", grid->id);
  185.             return 0;
  186.         }
  187.         grid = grid->next;
  188.     }
  189.     return 1;
  190. }

  191. void adminstrator(GRIDP grid)
  192. {
  193.     GRIDP head = grid;
  194.     uchar i = 0;
  195.     for (; i<N; i++)
  196.     {
  197.         if (grid->status)
  198.         {
  199.             printf("请检查格子号:%d 是否存在物品\n", grid->id);
  200.         }
  201.         grid = grid->next;
  202.     }
  203.     printf("储物柜格子已经全部打开!\n");
  204.    
  205.     // 默认管理员会清空全部格子
  206.     grid = head;
  207.     for (i=0; i<N; i++)
  208.     {
  209.         grid->status = 0;
  210.         grid = grid->next;
  211.     }
  212. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-8-23 13:49:51 | 显示全部楼层
感觉可以用数组来解决:A[3][10],A[0][i] 设置是否空闲,满 = 1,闲 = 0;A[1][i] 设置个人密码;A[2][i] 设置万能密码。

然后,调用子函数分别来解决投硬币、输密码及退出。

先看看大佬们的,我要去上班,晚上回来,试写一下,看这个方案行还是不行
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-8-23 14:14:49 | 显示全部楼层
初学就写这么长的东西。。。
我们来想想超市货物柜
首先上面有按键。和键盘一样,按下某某键,会有一个值过去。我们用键盘模拟
就用1,2,0,5来表示当时按键返回的不同键值吧
那么:一开始就有一个输入接收器等着,分别接收1,2,0,5。若是其它值则没有反应
可以分别为1,2,0,5设计相应的函数。也可以直接一体全在main中实现。看你自己了
另外,要有个显示函数,用来显示当前情况。这个显示函数根据不同的值来显示不同的页面
输入寄存时,先检查箱子是否已满

而根据超市货柜来看,应该是满了就直接显示已满,再输入寄件就没反应或者提示别的。所以一开始也可以直接检查。这是个循环,因为一直在运行。先检查是否已满,再决定要接收哪几个键。也可以在寄件那个键的函数里选择,根据是否已满进行不同的操作和显示

输密码的键接收后调取输密码函数

其他也一样。
投币可以进行选择或比较。不是1统统无效

除了干这事,还需要一个函数或者变量,来记哪几个箱子被使用了。可以用数组来记。使用与否值不一样,因此只需要一位来记。bool变量正好。万能钥匙使用时,检查这些编号是否使用中,是就显示某些东西,不是就不显示。

有人输密码取件后,相应编号的变量值变更为未使用。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-8-23 17:55:52 | 显示全部楼层
405794672 发表于 2020-8-23 14:14
初学就写这么长的东西。。。
我们来想想超市货物柜
首先上面有按键。和键盘一样,按下某某键,会有一个值 ...

谢谢大佬啦,弄出来了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-8-23 17:57:15 | 显示全部楼层
风过无痕1989 发表于 2020-8-23 13:49
感觉可以用数组来解决:A[3][10],A[0] 设置是否空闲,满 = 1,闲 = 0;A[1] 设置个人密码;A[2] 设置万能 ...

谢谢大佬啦,我弄了一下午弄出来了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-8-24 14:57:40 | 显示全部楼层    本楼为最佳答案   
本帖最后由 Cool_Breeze 于 2020-8-24 15:28 编辑

# 当练习题做了
  1. /*
  2. # 还有许多功能没有写!
  3. # BY Cool_Breeze
  4. # 2020/08/24
  5. # GCC .c
  6. */

  7. #include<stdio.h>
  8. #include<malloc.h>


  9. typedef unsigned char uchar;
  10. typedef unsigned int uint;

  11. #define N 10 // 格子数量
  12. uchar ABLE = 0; //可用箱子数量


  13. typedef struct GRID
  14. {
  15.     uchar id;
  16.     uchar status;
  17.     uint password;
  18.     struct GRID* next;
  19. }GRIDV,*GRIDP;

  20. // 初始化储物柜格子
  21. GRIDP __init__(void);

  22. // 打印格子信息
  23. // check = 1 只打印可用数量
  24. // check = 2 打印格子信息和可用数量
  25. // check = 0 检查可用格子数量
  26. void print_grid(GRIDP grid, uchar check);

  27. // 操作菜单
  28. uchar operation_menu(GRIDP head);

  29. // 存物品
  30. void store_items(GRIDP);

  31. // 取物品
  32. uchar get_items(GRIDP head, int* passwd);

  33. // 管理员
  34. void adminstrator(GRIDP grid);

  35. int main(void)
  36. {
  37.     //system("chcp 936");
  38.     GRIDP locker = __init__();
  39.     print_grid(locker, 1);
  40.     operation_menu(locker);
  41.    
  42.     return 0;
  43. }

  44. GRIDP __init__(void)
  45. {
  46.     uchar i = 0;
  47.     GRIDP head, cnter, grid;
  48.    
  49.     for (; i<N; i++)
  50.     {
  51.         grid = (GRIDP)malloc(sizeof(GRIDV));
  52.         if (i == 0)
  53.         {
  54.             head = cnter = grid;
  55.             grid->id = i + 1;
  56.             grid->status = 0;
  57.             grid->password = 0;
  58.             grid->next = NULL;
  59.         }
  60.         else
  61.         {
  62.             cnter->next = grid;
  63.             grid->id = i + 1;
  64.             grid->status = 0;
  65.             grid->password = 0;
  66.             grid->next = NULL;
  67.             cnter = grid;
  68.         }
  69.     }
  70.    
  71.     return head;
  72. }

  73. void print_grid(GRIDP grid, uchar check)
  74. {
  75.     ABLE = 0;
  76.     uchar i = 0;
  77.     for (; i<N; i++)
  78.     {
  79.         if (grid->status == 0) ABLE++;
  80.         if (check == 2)
  81.             printf("格子号:%d\t物品状态:%d\n", grid->id, grid->status);
  82.         grid = grid->next;
  83.     }
  84.     if (check) printf("可用格子数量为:%d\n", ABLE);
  85. }

  86. uchar operation_menu(GRIDP head)
  87. {
  88.     uchar i = 0;
  89.     uchar number = 0;
  90.     uchar ad_passwd[6] = {0};
  91.     uchar ad_pd_ok[6] = {'0','0','0','0','8','6'}; // 管理员密码
  92.     uint passwd[2] = {0};
  93.     while (1)
  94.     {
  95.         printf("\n1. 投硬币\t2. 取走物品\t3.查询可用格子数量\t0. 退出\n请选择:");
  96.         scanf("%d", &number);
  97.         getchar();
  98.         switch (number)
  99.         {
  100.             case 1:
  101.                 print_grid(head, 0);
  102.                 if (!ABLE)
  103.                 {
  104.                     printf("储物柜已满!\n");
  105.                     break;
  106.                 }
  107.                 else
  108.                 {
  109.                     store_items(head);
  110.                     break;
  111.                 }
  112.             case 2:
  113.                 while (1)
  114.                 {
  115.                     *passwd = 0;
  116.                     *(passwd+1) = 0;
  117.                     printf("请输入格子号:");
  118.                     scanf("%d", passwd);
  119.                     getchar();
  120.                     printf("请输入密码:");
  121.                     scanf("%d", passwd+1);
  122.                     getchar();
  123.                     if (get_items(head, passwd))
  124.                     {
  125.                         printf("输入密码或者格子号错误!请重新选择\n");
  126.                         break;
  127.                     }
  128.                     break;   
  129.                 }
  130.                 break;
  131.             case 3:
  132.                 print_grid(head, 1);
  133.                 break;
  134.             case 5:
  135.                 printf("请输入管理员密码:");
  136.                 scanf("%s", ad_passwd);
  137.                 getchar();
  138.                 for (i=0; i<6; i++)
  139.                 {
  140.                     if (*(ad_passwd + i ) == *(ad_pd_ok + i ))
  141.                         continue;
  142.                     else
  143.                     {
  144.                         printf("管理员密码错误!请重新选择\n");
  145.                         break;
  146.                     }
  147.                 }
  148.                 if (i == 6)
  149.                 {
  150.                     adminstrator(head);
  151.                     break;
  152.                 }
  153.                 break;
  154.             case 0:
  155.                 return 0;
  156.         }
  157.     }
  158.     return 0;
  159. }

  160. void store_items(GRIDP grid)
  161. {
  162.     // 密码就不写了
  163.     uchar i = 0;
  164.     for (; i<N; i++)
  165.     {
  166.         if (grid->status == 0)
  167.         {
  168.             grid->status = 1;
  169.             grid->password = 9342;
  170.             printf("格子号:%d\t密码:%d\n", grid->id, 9342);
  171.             break;
  172.         }
  173.         grid = grid->next;
  174.     }
  175. }

  176. uchar get_items(GRIDP grid, int* passwd)
  177. {
  178.     uchar i = 0;
  179.     for (; i<N; i++)
  180.     {
  181.         if (grid->id == *passwd && grid->password == *(passwd+1))
  182.         {
  183.             grid->status = 0;
  184.             printf("格子号:%d 已打开\n", grid->id);
  185.             return 0;
  186.         }
  187.         grid = grid->next;
  188.     }
  189.     return 1;
  190. }

  191. void adminstrator(GRIDP grid)
  192. {
  193.     GRIDP head = grid;
  194.     uchar i = 0;
  195.     for (; i<N; i++)
  196.     {
  197.         if (grid->status)
  198.         {
  199.             printf("请检查格子号:%d 是否存在物品\n", grid->id);
  200.         }
  201.         grid = grid->next;
  202.     }
  203.     printf("储物柜格子已经全部打开!\n");
  204.    
  205.     // 默认管理员会清空全部格子
  206.     grid = head;
  207.     for (i=0; i<N; i++)
  208.     {
  209.         grid->status = 0;
  210.         grid = grid->next;
  211.     }
  212. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-8-26 20:06:44 | 显示全部楼层

辛苦大佬了,感谢感谢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-8-26 20:09:59 | 显示全部楼层

后来做出来了,只不过方法没有你的高端
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-8-26 20:22:32 | 显示全部楼层
Christopher. 发表于 2020-8-26 20:09
后来做出来了,只不过方法没有你的高端

慢慢来,积少成多,熟能生巧!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-16 14:50

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表