惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

T
Tenable Blog
Last Week in AI
Last Week in AI
P
Proofpoint News Feed
Engineering at Meta
Engineering at Meta
H
Help Net Security
F
Fortinet All Blogs
MyScale Blog
MyScale Blog
宝玉的分享
宝玉的分享
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
博客园 - 司徒正美
量子位
N
Netflix TechBlog - Medium
Apple Machine Learning Research
Apple Machine Learning Research
小众软件
小众软件
Recorded Future
Recorded Future
博客园 - 三生石上(FineUI控件)
Vercel News
Vercel News
aimingoo的专栏
aimingoo的专栏
I
InfoQ
Microsoft Security Blog
Microsoft Security Blog
Scott Helme
Scott Helme
The Last Watchdog
The Last Watchdog
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
IT之家
IT之家
AI
AI
WordPress大学
WordPress大学
Security Archives - TechRepublic
Security Archives - TechRepublic
Google Online Security Blog
Google Online Security Blog
U
Unit 42
V2EX - 技术
V2EX - 技术
MongoDB | Blog
MongoDB | Blog
Schneier on Security
Schneier on Security
博客园 - Franky
H
Heimdal Security Blog
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Jina AI
Jina AI
W
WeLiveSecurity
P
Privacy & Cybersecurity Law Blog
Cloudbric
Cloudbric
B
Blog RSS Feed
N
News | PayPal Newsroom
S
Securelist
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
I
Intezer
Hacker News - Newest:
Hacker News - Newest: "LLM"
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
博客园_首页
罗磊的独立博客
H
Hackread – Cybersecurity News, Data Breaches, AI and More
雷峰网
雷峰网

博客园 - NOIP/NOI辅导

ubuntu下查看(改变)本地端口开放情况,开启和关闭防火墙 [NOIP] - CCF NOIP2018普及组初赛试题+答案 [NOIP] - 阶乘之和 [NOIP题目] - 方格取数 [NOIP题目] - 铺地毯 [NOIP题目] - 马拦过河卒 中小学阶段,学习NOIP信息学有用吗? [信息学奥赛] NOI2018冬令营获奖名单 信息学奥赛介绍 五大学科竞赛 从哪个年级学习信息学奥赛好呢? NOI-001 —《C++编程及竞赛训练》 NOI-002 —《普及组竞赛强化训练课程》 NOI-003 —《初级算法课程》 [iOS] 解决Xcode rename failed的问题 [Android] - Android Studio 执行Log.v和Log.d 不显示打印 [Git] 403 error [React-Native] RelativeLayout是相对布局控件 - 转 [Android] 代码中动态设置shape
[NOI题目] - 抽签
NOIP/NOI辅导 · 2018-09-23 · via 博客园 - NOIP/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;
}