中兴面试题之中的一个。难度系数中。

题目描写叙述例如以下:输入两个整数n 和m,从数列1,2。3.......n 中任意取几个数,

使其和等于m ,要求将当中全部的可能组合列出来。

逻辑分析:

1、比起微软,google,百度这些公司,中兴的面试题还是略显逗比的,并不是是说难度上差异,而是中兴的题目总是显得不伦不类。本题事实上就是考察数的组合,对于此类问题。通常手段都是递归,而我们的目标就在于找出递归式。

2、问题事实上本质上就是0/1背包问题,对于每个n,我们採用贪婪策略,先考察是否取n,假设取n,那么子问题就变成了find(n-1,m-n),而假设舍弃n,子问题则为find(n-1,m)。至此。我们利用DP思想找到了递归式(非常多时候。所谓动态规划,贪婪仅仅是一念之差)。

3、那么,怎样制定解的判定策略?我们知道。递归须要边界条件,而针对背包问题,边界条件仅仅有两种,假设n<1或者m<1,那么便相当于“溢出”,无法combo出m,而还有一种可能就是在剩余的n个里恰好满足m==n,即此时 背包刚好填充满。输出一组解单元。除此之外。再无其它。

C源代码:

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>
  4.  
  5. int length;
  6.  
  7. void findCombination(int n,int m,int *flag)
  8. {
  9. if(n < 1 || m < 1)
  10. return;
  11. if(n > m)
  12. n = m;
  13. if(n == m)
  14. {
  15. flag[n-1] = 1;
  16. for(int i=0;i<length;i++)
  17. {
  18. if(flag[i] == 1)
  19. printf("%d\t",i+1);
  20. }
  21. printf("\n");
  22. flag[n-1] = 0;
  23. }
  24. flag[n-1] = 1;
  25. findCombination(n-1,m-n,flag);
  26. flag[n-1] = 0;
  27.  
  28. findCombination(n-1,m,flag);
  29. }
  30.  
  31. int main()
  32. {
  33. int n, m;
  34. scanf("%d%d",&n,&m);
  35. length = n;
  36. int *flag = (int*)malloc(sizeof(int)*length);
  37. findCombination(n,m,flag);
  38. free(flag);
  39. return 0;
  40. }

注:我们设置flag背包,用来标注相应的n+1是否被选中,1表示被选中。0则表示未选中,每当满足m==n时,则输出一组解。

程序easy产生逻辑bug的地方在于length的使用(读者能够思考一下为何须要全局变量length。而不是直接使用n来取代for循环)。

输入两个整数n 和m,从数列1,2,3.......n 中任意取几个数, 使其和等于m ,要求将当中全部的可能组合列出来的更多相关文章

  1. 【编程题目】输入两个整数 n 和 m,从数列 1,2,3.......n 中 随意取几个数, 使其和等于 m ... ★

    第 21 题(数组)2010 年中兴面试题编程求解:输入两个整数 n 和 m,从数列 1,2,3.......n 中 随意取几个数,使其和等于 m ,要求将其中所有的可能组合列出来. 我的思路: 从小 ...

  2. 面试题:输入两个整数 n 和 m,从数列1,2,3…….n 中 随意取几个数, 使其和等于 m

    问题: 2010年中兴面试题 编程求解: 输入两个整数 n 和 m,从数列1,2,3…….n 中 随意取几个数, 使其和等于 m ,要求将其中所有的可能组合列出来. 思路: 类似这种组合问题一般都是使 ...

  3. 编程求解,输入两个整数n和m,从数列1,2,3,……n中随意取几个数,使其和等于m。要求将所有的可能组合列出来

    import java.util.LinkedList; import java.util.Scanner; public class Main { private static LinkedList ...

  4. 输入两个整数n和m,从数列1,2,3,……n中随意取几个数,使其和等于m

    题目:编程求解,输入两个整数n和m,从数列1,2,3,……n中随意取几个数,使其和等于m.要求将所有的可能组合列出来. 分析:分治的思想.可以把问题(m,n)拆分(m - n, n -1)和(m, n ...

  5. ytu 1057: 输入两个整数,求他们相除的余数(带参的宏 + 模板函数 练习)

    1057: 输入两个整数,求他们相除的余数 Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 177  Solved: 136[Submit][Status ...

  6. Gym 101064 D Black Hills golden jewels 【二分套二分/给定一个序列,从序列中任意取两个数形成一个和,两个数不可相同,要求求出第k小的组合】

    D. Black Hills golden jewels time limit per test 2 seconds memory limit per test 256 megabytes input ...

  7. 从数组中任意取出2个数,判断他们的和是否为输入的数字sum,时间复杂度为0(n^2),空间复杂度0(1)

    从数组中任意取出2个数,判断他们的和是否为输入的数字sum,时间复杂度为0(n^2),空间复杂度0(1) 假设数据已经是排序好的 #include <stdio.h> #include & ...

  8. c++作业:输入两个整数,用函数求两数之和。函数外部声明有什么作用?

    #include <iostream> using namespace std; int main(){ //求两数的和? int a,b,s; cout<<"请你输 ...

  9. JS写一个简单的程序,输入两个整数,打印这两个数的和,差,积,余数

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

随机推荐

  1. ch1 About thinking skills

    When confronted with a problem , we think about it. The issue, of course, is that our efforts may be ...

  2. Pyhton TestCase运行闪退与失败,原因不详。。。

    把源码贴上来,希望某位大神可以指点迷津: """Unit test for odbchelper.py This program is part of "Div ...

  3. linux gcc编译protocol

    gcc -c test.pb-c.c//生成test.pb-c.o文件 gcc -c udp_socket_server.c//生成udp_socket_server.o gcc -o test1 u ...

  4. Oracle 把一个用户所有表的读权限授予另一个用户

    create user <USER_NAME> identified by <PASSWORD>; grant create session TO <USER_NAME& ...

  5. 数据库——DBUtils和连接池

    第一章 DBUtils如果只使用JDBC进行开发,我们会发现冗余代码过多,为了简化JDBC开发,本案例我们讲采用apache commons组件一个成员:DBUtils.DBUtils就是JDBC的简 ...

  6. JS设计模式—节流模式的实际应用

    在实际工作中,我们会经常遇到这样的业务场景,比如点击按钮提交表单,点击一次发一次请求,如果快速点击多次会发送多次请求,这样发送了多次请求是我们不愿意看到的.又比如输入框我们输入内容会调搜索的接口,那么 ...

  7. Loj #6000.「 网络流 24 题 」搭配飞行员

    解题思路 考虑如何建模. 既然是网络流,那么肯定要有源点和汇点.而这个题目并没有什么明显的源点和汇点. 想一想,如果一个飞机能够起飞的话,那么必定有一对可以配对的正副驾驶员.也就是说一条曾广路能够上必 ...

  8. [Python数据结构] 使用 Circular List实现Queue

    [Python数据结构] 使用 Circular List实现Queue 1. Queue队列,又称为伫列(queue),是先进先出(FIFO, First-In-First-Out)的线性表.在具体 ...

  9. HTTP服务和APACHE

    HTTP服务和APACHE 1. 跨Internet的主机间通讯 要通过Internet进行通信,至少需要一对套接字:其中一个运行在客户端,定义了一个唯一的客户进程,称之为ClientSocket,另 ...

  10. 访问请求参数request.getParameter()

    访问请求参数request.getParameter() 制作人:全心全意 getParameter() 例: 传递参数页: <%@ page language="java" ...