枚举

- 日理万妓 2021-12-16 15:34 435阅读 0赞
  1. 枚举(穷举,暴力求解)

一.基本思想

  1. 对问题变量可能解集合的每一个元素,根据问题给出的检验条件判定哪些是成立的,使条件成立的元素即是问题的解。

二.例题

1.假币问题:

问题描述:

  赛利有12枚银币。其中有11枚真币和1枚假币。假币看起来和真币没有区别,但是重量不同。但赛利不知道假币比真币轻还是重。于是他向朋友借了一架天平。朋友希望赛利称三次就能找出假币并且确定假币是轻是重。例如:如果赛利用天平称两枚硬币,发现天平平衡,说明两枚都是真的。如果赛利用一枚真币与另一枚银币比较,发现它比真币轻或重,说明它是假币。经过精心安排每次的称量,赛利保证在称三次后确定假币。

输入数据:

  输入第一行有一个数字n,表示有n组测试用例。
  对于每组测试用例:
  输入有三行,每行表示一次称量的结果。赛利事先将银币标号为A-L。每次称量的结果用三个以空格隔开的字符串表示:天平左边放置的硬币 天平右边放置的硬币 平衡状态。其中平衡状态用``up’’, ``down’’, 或 ``even’’表示, 分别为右端高、右端低和平衡。天平左右的硬币数总是相等的。

输出要求:

  输出输出哪一个标号的银币是假币,并说明它比真币轻还是重(heavy or light)。

样例输入:

  1. 1
  2. ABCD EFGH even
  3. ABCI EFJK up
  4. ABIJ EFGH even

样例输出:

  1. K is the counterfeit coin and it is light.
  2. #include <stdio.h>
  3. #include <stdlib.h>
  4. char left[3][7],right[3][7],result[3][7];
  5. int state[12];
  6. //判断在假设条件下是否满足条件
  7. int isRight()
  8. {
  9. int leftSum,rightSum,i,j;
  10. for(i=0;i<3;i++)
  11. {
  12. leftSum=0,rightSum=0;
  13. for(j=0;j<6&&left[i][j]!=0;j++)
  14. {
  15. leftSum += state[left[i][j]-'A'];
  16. rightSum += state[right[i][j]-'A'];
  17. }
  18. if(leftSum>rightSum && result[i][0]!='u') //左边更重但不为up
  19. return 0;
  20. if(leftSum==rightSum && result[i][0]!='e') //两边相等但不为equal
  21. return 0;
  22. if(leftSum<rightSum && result[i][0]!='d') //右边更重但不为down
  23. return 0;
  24. }
  25. return 5;
  26. }
  27. int main()
  28. {
  29. int n,x,y,k;
  30. scanf("%d",&n);
  31. for(x=0;x<n;x++)
  32. {
  33. for(y=0;y<3;y++)
  34. {
  35. scanf("%s %s %s",left[y],right[y],result[y]);
  36. }
  37. memset(state,0,sizeof(state));
  38. for(k=0;k<12;k++)
  39. {
  40. state[k] = 1; //假设第i枚硬币是较重硬币
  41. if(isRight())
  42. break;
  43. state[k] = -1; //假设第i枚硬币是较轻硬币
  44. if(isRight())
  45. break;
  46. state[k] = 0; //假设第i枚硬币是真币
  47. }
  48. if(state[k] > 0)
  49. printf("%c is the counterfeit coin and it is heavy.\n",k+'A');
  50. if(state[k] < 0)
  51. printf("%c is the counterfeit coin and it is light.\n",k+'A');
  52. }
  53. return 0;
  54. }

2.生理周期

问题描述:

  人生来就有三个生理周期,分别为体力周期、感情周期和智力周期,它们的周期长度分别为23天、28天和33天。每一个周期中有一天是高峰。在高峰这天,人会在相应的方面表现出色。例如,在智力周期的高峰,人会思维敏捷,注意力容易高度集中。因为三个周期的长度不同,所以通常三个周期的高峰不会落在同一天。对于每个人,想知道何时三个高峰落在同一天。对于每个周期,会给出从当前年份的第一天开始,到出现高峰的天数(不一定是第一次高峰出现的时间)。给定一个从当年第一天开始的天数,你的任务是输出从给定时间开始(不包括给定时间),下一次三个高峰落在同一天的时间(距给定时间的天数)。例如:给定时间为10,下次出现三个高峰同一天的时间是12,则输出2(注意这里不是3)。

输入要求:

  1. 输入包含多组数据,每一组数据由四个整数组成,数据以-1 -1 -1 -1 结束。
  2. 对于四个整数p, e, idp, e, i分别表示体力、情感和智力高峰出现的时间(时间从当年的第一天开始计算)。d是给定的时间,可能小于p, ei。所有给定时间是非负的并且小于或等于365,所求的时间小于或等于21252

输出要求:

  从给定时间起,下一次三个高峰同一天的时间(距离给定时间的天数)。

样例输入:

  1. 0 0 0 0
  2. 0 0 0 100
  3. 5 20 34 325
  4. 4 5 6 7
  5. 283 102 23 320
  6. 203 301 203 40
  7. -1 -1 -1 -1

样例输出:

  1. Case 1: the next triple peak occurs in 21252 days.
  2. Case 2: the next triple peak occurs in 21152 days.
  3. Case 3: the next triple peak occurs in 19575 days.
  4. Case 4: the next triple peak occurs in 16994 days.
  5. Case 5: the next triple peak occurs in 8910 days.
  6. Case 6: the next triple peak occurs in 10789 days.
  7. #include <stdio.h>
  8. #include <stdlib.h>
  9. int main()
  10. {
  11. int d,p,e,i,p1,e1,i1,j=0,k,m;
  12. scanf("%d %d %d %d",&p,&e,&i,&d);
  13. while(d!=-1 && p!=-1 && e!=-1 && i!=-1)
  14. {
  15. j++;
  16. p1 = p%23;
  17. e1 = e%28;
  18. i1 = i%33;
  19. for(m=i+1;;m++) //找到第一个智力高峰
  20. {
  21. if(m%33 == i1)
  22. {
  23. break;
  24. }
  25. }
  26. for(k=m;k<=21252;k+=33) //在智力高峰上找到第一个情感高峰
  27. {
  28. if(k%28==e1)
  29. {
  30. break;
  31. }
  32. }
  33. for(m=k;m<=21252;m+=33*28) //在前两者的公共高峰上找到第一个体力高峰
  34. {
  35. if(m%23==p1)
  36. {
  37. printf("Case %d:the next triple peak occers in %d days\n",j,m-d);
  38. break;
  39. }
  40. }
  41. scanf("%d %d %d %d",&p,&e,&i,&d);
  42. }
  43. return 0;
  44. }

3.完美立方

描述:

  形如a3= b3 + c3 + d3的等式被称为完美立方等式。例如123= 63 + 83 + 103 。编写一个程序,对任给的正整数N (N≤100),寻找所有的四元组(a, b, c, d),使得a3 = b3 + c3 + d3,其中a,b,c,d 大于 1, 小于等于N,且b<=c<=d。

输入数据:

  一个正整数N (N≤100)。

输出格式为:

  Cube = a, Triple = (b,c,d)

  请按照a的值,从小到大依次输出,当两个完美立方等式中a的值相同,则b值小的优先输出,仍相同则c值小的优先输出,再相同则d值小的先输出。

样例输入

  1. 24

样例输出

  1. Cube = 6, Triple = (3,4,5)
  2. Cube = 12, Triple = (6,8,10)
  3. Cube = 18, Triple = (2,12,16)
  4. Cube = 18, Triple = (9,12,15)
  5. Cube = 19, Triple = (3,10,18)
  6. Cube = 20, Triple = (7,14,17)
  7. Cube = 24, Triple = (12,16,20)
  8. #include <stdio.h>
  9. #include <stdlib.h>
  10. int cube[100];
  11. int main()
  12. {
  13. int n,i,a,b,c,d;
  14. scanf("%d",&n);
  15. for(i=2;i<=n;i++)
  16. {
  17. cube[i] = i*i*i;
  18. }
  19. for(a=6;a<=n;a++) //通过计算,6以前没有满足条件的b,c,d
  20. {
  21. for(b=2;b<a;b++) //通过确定b,c,d的初始值,来使它们非降序排列,并且小的先输出。
  22. {
  23. for(c=b;c<a;c++)
  24. {
  25. for(d=c;d<a;d++)
  26. {
  27. if(cube[a] == cube[b]+cube[c]+cube[d])
  28. {
  29. printf("Cube = %d,Triple = (%d,%d,%d)\n",a,b,c,d);
  30. }
  31. }
  32. }
  33. }
  34. }
  35. return 0;
  36. }

转载于:https://www.cnblogs.com/ljlzl/p/10865351.html

发表评论

表情:
评论列表 (有 0 条评论,435人围观)

还没有评论,来说两句吧...

相关阅读

    相关

    在学C++和做一些实践的时候发现,枚举类型有时候是必要的。 有时我们希望某些常量只在类中有效。由于\define定义的宏常量是全局的,不能达到目的,于是想当然地觉得应该用co

    相关

    当定义一个枚举时,编译器就会创建一个扩展java.lang.Enum类的类定义。这个类是java.lang.Object的一个直接后代。但与普通类不同的是,枚举具有以下属性:

    相关

      在第一次学习面向对象编程时,我记得最深的一句话就是“万物皆对象”。于是我一直秉承着这个思想努力的学习着JAVA,直到学习到枚举(Enum)时,看着它颇为奇怪的语法……我一直

    相关

    JDK1.5之前需要自定义枚举类 JDK 1.5 新增的 enum 关键字用于定义枚举类 若枚举只有一个成员, 则可以作为一种单例模式的实现方式 枚举类对象的属性

    相关

    枚举 什么是枚举? 枚举指的是在一定范围内取值,这个值必须是枚举类型中的任意一个,而且只能够取其中的一个 枚举的特点: 1.枚举的本质就是一个Java类

    相关

                                       枚举(穷举,暴力求解) 一.基本思想         对问题变量可能解集合的每一个元素,根据问题给出