uva 10344 - 23 out of 5

本文介绍了一种解决23点游戏的算法实现方案。通过全排列和深度优先搜索的方法,利用五张牌和三种运算符(乘、加、减),判断是否可以组合得到23点。代码使用C++实现,通过全排列确保所有可能性都被考虑。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

点击打开链接


题目意思:给定5个数,还有三种运算符 * + - ,问我们是否能够由这些数和运算符最后的值为23。


解题思路:我们知道5个数的全排列为5!种,那么我们只要去枚举这个全排列中每一个排列进行搜索,是否有23点出现有的话标记ans为1,直接退出。(注意必须全排列的查找,不能只按输入的顺序)


代码:

//计算5个数3个运算符能否组成23点
//我们知道5个数的全排列为5!种,那么我们只要去枚举这个全排列中每一个排列进行搜索,是否有23点出现有的话标记ans为1,直接退出。(注意必须全排列的查找,不能只按输入的顺序)
#include <iostream>
#include <cstdio>
#include <cmath>
#include <algorithm>
using namespace std;

int ans;
int num[5];
char ope[3] = {'*' , '+' , '-'};//运算符数组

//搜索
void dfs(int k , int sum){
    if(k >= 5){//如果计算完成,判断是否有23点出现
        if(sum == 23)
            ans = 1;
        return;
    }
    if(k < 5){
        for(int i = 0 ; i < 3 ; i++){//搜索三种符号
            //三种情况回溯,注意现场的恢复
            if(i == 0){
                sum *= num[k];
                dfs(k+1 , sum);
                sum /= num[k];
            }
            if(i == 1){
                sum += num[k];
                dfs(k+1 , sum);
                sum -= num[k];
            }
            if(i == 2){
                sum -= num[k];
                dfs(k+1 , sum);
                sum += num[k];
            }
        }
        ++k;//下一个数
    }
}

//
int main(){
    int sum;
    while(1){
        sum = 0;
        ans = 0;
        for(int i = 0 ; i < 5 ; i++){
            scanf("%d" , &num[i]);
            sum += num[i];
        }
        if(sum == 0) break;//全为0直接退出
        else{
            sort(num , num+5);//先排序
            dfs(1 , num[0]);//求一下第一个顺序
            if(ans) 
                printf("Possible\n");
            else{
                while(next_permutation(num , num+5)){//全排列
                    dfs(1 , num[0]);
                    if(ans){//搜索到了,直接退出
                        break;
                    }
                }
                if(ans) printf("Possible\n");
                else    printf("Impossible\n");
            }   
        }
    }
    return 0;
}


资源下载链接为: https://pan.quark.cn/s/22ca96b7bd39 在当今的软件开发领域,自动化构建与发布是提升开发效率和项目质量的关键环节。Jenkins Pipeline作为一种强大的自动化工具,能够有效助力Java项目的快速构建、测试及部署。本文将详细介绍如何利用Jenkins Pipeline实现Java项目的自动化构建与发布。 Jenkins Pipeline简介 Jenkins Pipeline是运行在Jenkins上的一套工作流框架,它将原本分散在单个或多个节点上独立运行的任务串联起来,实现复杂流程的编排与可视化。它是Jenkins 2.X的核心特性之一,推动了Jenkins从持续集成(CI)向持续交付(CD)及DevOps的转变。 创建Pipeline项目 要使用Jenkins Pipeline自动化构建发布Java项目,首先需要创建Pipeline项目。具体步骤如下: 登录Jenkins,点击“新建项”,选择“Pipeline”。 输入项目名称和描述,点击“确定”。 在Pipeline脚本中定义项目字典、发版脚本和预发布脚本。 编写Pipeline脚本 Pipeline脚本是Jenkins Pipeline的核心,用于定义自动化构建和发布的流程。以下是一个简单的Pipeline脚本示例: 在上述脚本中,定义了四个阶段:Checkout、Build、Push package和Deploy/Rollback。每个阶段都可以根据实际需求进行配置和调整。 通过Jenkins Pipeline自动化构建发布Java项目,可以显著提升开发效率和项目质量。借助Pipeline,我们能够轻松实现自动化构建、测试和部署,从而提高项目的整体质量和可靠性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值