[NOI题目] - 抽签

题干

你的朋友提议玩一个游戏:将写有数字的n个纸片放入口袋中,你可以从口袋中抽取4次纸片,每次记下纸片上的数字后都将其放回口袋中。

如果这4个数字的和是m,就是你赢,入则就是你的朋友赢。你挑战了好机会,结果一次也没赢过,也是怒而撕破口袋,取出所有纸片,检查自己是否真的有赢的可能性。

要求

请编写一个程序,判断当纸片上所写的数字是k1, k2, …, kn时,是否存在抽取4次和为m的方案。

如果存在,输出Yes;否则,输出No。

限制条件:

1 <= n <= 50

1 <= m <= 10^8

1 <= Ki <= 10^8

样例:

输入:

n = 3

m = 10

k = {1, 3, 5}

输出:

Yes(例如4次抽取的结果是1、1、3、5,和就是10)

解答:

//  main.cpp
//  testForCPP
//
//  Created on 2018/9/6.
//  Copyright © 2018. All rights reserved.
//

#include <iostream>

using namespace std;

const int MAX_N = 50;

int main(int argc, const char * argv[]) {
   
    int n, m, k[MAX_N];
    
    //从标准输入读入
    scanf("%d %d", &n, &m);
    
    cout << "n = " << n << "; m =" << m << endl;
    
    for(int i = 0; i < n; i++){
        scanf("%d", &k[i]);
    }
    
    //是否找到和为m的组合的标记
    bool f = false;
    
    //通过四重循环枚举所有方案
    for (int a = 0; a < n; a++){
        for(int b = 0; b < n; b++){
            for(int c = 0; c < n; c++){
                for(int d = 0; d < n; d++){
                    if(k[a] + k[b] + k[c] + k[d] == m){
                        f = true;
                    }
                }
            }
        }
    }
    
    //输出到标准输出
    if(f) puts("Yes");
    else puts("No");
    
    return 0;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 在C语言中,五种基本数据类型存储空间长度的排列顺序是: A)char B)char=int<=float C)ch...
    夏天再来阅读 3,407评论 0 2
  • 各校历年复试机试试题 清华、北大、华科试题详细笔记部分,少笔记部分与少数leetcode【含个人整理笔记】 一、详...
    十里江城阅读 1,218评论 0 1
  • 今天我们来介绍三位模特,有你喜欢的吗? 你为什么旅拍?小编问了她们如下的问题,看看她们的解答吧! 1、自我介绍一下...
    一半旅行_阅读 1,033评论 0 1
  • 从没放弃 诗的远方 任脚下的路 凝重漫长 一往无前 黑山恒咽阳光 脚步依然坚定 背影拉长 或许山的那边 只尽凄凉 ...
    垄上行云阅读 96评论 0 2
  • 乌龟总是在路上 一步一步 看着兔子到达了终点
    椹一阅读 105评论 0 1