zoukankan      html  css  js  c++  java
  • zoj ZOJ 3196 Give me the result

    http://acm.sdibt.edu.cn:8080/judge/contest/view.action?cid=579#problem/D

    题意:给出一段数,每相邻两个数字之间用+,-,*,/四个符号中的一个,忽略乘除的优先级,优先顺序为从左到右,

             问如何安排符号使最后的结果最大,并且sum的最后结果每位数字不能含有k

    分析:DFS~~

    这道题很水,但是如果队友不指出错误的话,依旧找不到错在哪,很明显,在判断每位数字的时候,若sum=0的话循环进不去,这时候

    若k也等于0,就会返回true,而正确应该是false

    #include<stdio.h>
    #include<math.h>
    #include<algorithm>
    #include<string.h>
    using namespace std;
    const int MN=20;
    long long num[MN];
    long long ans;
    long long n,k;
    
    bool OK(long long sum)//若sum=0的话,循环是不会进去的
    {
        if(sum==0 && k==0) return false;
        if(sum==0 && k!=0) return true;
        while(sum)
        {
            if(sum%10==k) return false;
            sum/=10;
        }
        return true;
    }
    
    void DFS(int cur,long long sum)
    {
        if(cur==n-1)
        {
            if(sum>ans && OK(sum)) ans=sum;
            return ;
        }
        DFS(cur+1,sum+num[cur+1]);
        DFS(cur+1,sum*num[cur+1]);
        if(sum>num[cur+1]) DFS(cur+1,sum-num[cur+1]);
        else DFS(cur+1,num[cur+1]-sum);
        if(num[cur+1]!=0) DFS(cur+1,sum/num[cur+1]);
    }
    
    int main()
    {
        int i,j,T;
        while(scanf("%d",&T)!=EOF)
        {
            while(T--)
            {
                scanf("%lld%lld",&n,&k);
                ans=-10;
                for(i=0; i<n; i++)
                {
                    scanf("%lld",&num[i]);
                }
                DFS(0,num[0]);
    
                if(ans<0) printf("No result\n");
                else printf("%lld\n",ans);
            }
        }
        return 0;
    }
  • 相关阅读:
    LeetCode(65):有效数字
    LeetCode(64):最小路径和
    物理Data Guard的日常维护
    Oracle Data Guard的配置
    SQL基础--完整性约束
    使用rman迁移数据库到异机
    Oracle的表空间和数据文件
    Oracle的控制文件
    Oracle重做日志文件
    RMAN的恢复篇
  • 原文地址:https://www.cnblogs.com/zsboy/p/2954979.html
Copyright © 2011-2022 走看看