zoukankan      html  css  js  c++  java
  • ACM题目————The partial sum problem

    描述
    One day,Tom’s girlfriend give him an array A which contains N integers and asked him:Can you choose some integers from the N integers and the sum of them is equal to K. 
    输入
    There are multiple test cases.
    Each test case contains three lines.The first line is an integer N(1≤N≤20),represents the array contains N integers. The second line contains N integers,the ith integer represents A[i](-10^8≤A[i]≤10^8).The third line contains an integer K(-10^8≤K≤10^8).
    输出
    If Tom can choose some integers from the array and their them is K,printf ”Of course,I can!”; other printf ”Sorry,I can’t!”.
    样例输入
    4
    1 2 4 7
    13
    4
    1 2 4 7
    15
    样例输出

    Of course,I can!

    Sorry,I can't!

    题目大意就是,给你n个数, 再给一个sum,能不能用这n个数,加起来等于sum!

    主要难点在减少循环。

    //时间超限代码:

    //Asimple
    #include <stdio.h>
    #include <iostream>
    #include <string.h>
    using namespace std;
    #define CLS(a) memset(a,0,sizeof (a))
    const int maxn = 25;
    int n, T, num, cnt, point, line, x, y;
    int vis[maxn];//标记数组,标记是否走过
    int a[maxn];
    bool flag;
    
    bool check()
    {
        for(int i=0; i<n; i++)
            if( !vis[i] )
                return false ;
        return true;
    }
    
    void DFS(int cnt)
    {
        if( check() ) return ;
        if( cnt == num )
        {
            flag = true ;
            return ;
        }
        for(int i=0; i<n; i++)
        {
            if( !vis[i] && cnt + a[i] <= num )
            {
                vis[i] = 1 ;
                DFS(cnt + a[i] ) ;
                vis[i] = 0 ;
            }
        }
    }
    
    int main()
    {
        while( cin >> n )
        {
            cnt = 0 ;
            CLS(vis);
            flag = false ;
            for(int i=0; i<n; i++)
                cin >> a[i] ;
            cin >> num ;
            DFS(cnt);
            if( flag ) cout << "Of course,I can!" << endl ;
            else cout << "Sorry,I can't!" << endl ;
        }
    
        return 0;
    }
    

    减少循环后的代码:

    //Asimple
    #include <iostream>
    using namespace std;
    const int maxn = 25;
    int n, num, cnt;
    int a[maxn];
    bool flag;
    
    void DFS(int x)
    {
        if( cnt > num ) return ;
        if( cnt == num )
        {
            flag = true ;
            return ;
        }
        for(int i=x; i<n; i++)
        {
            cnt += a[i] ;
            DFS(i+1);
            cnt -= a[i] ;
        }
    }
    
    int main()
    {
        while( cin >> n )
        {
            cnt = 0 ;
            flag = false ;
            for(int i=0; i<n; i++)
                cin >> a[i] ;
            cin >> num ;
            DFS(0);
            if( flag ) cout << "Of course,I can!" << endl ;
            else cout << "Sorry,I can't!" << endl ;
        }
    
        return 0;
    }
    
    低调做人,高调做事。
  • 相关阅读:
    1101. Quick Sort (25)
    1100. Mars Numbers (20)
    1099. Build A Binary Search Tree (30)
    TCP四次挥手为何需要TIME_WAIT以及为何是2MSL?
    关于priority_queue运算符重载的问题
    leetcode151.翻转字符串里的单词
    华为笔试题--最长公共子串
    华为笔试题--表达式求值
    华为笔试题--字符串合并处理
    华为笔试题--删除字符串中出现次数最少的字符
  • 原文地址:https://www.cnblogs.com/Asimple/p/5546248.html
Copyright © 2011-2022 走看看