NOIP 2012 年普及组初赛试题整理「建议收藏」

NOIP 2012 年普及组初赛试题整理「建议收藏」问题求解题目答案:5题目解析:贪心法。构造出最坏情况下至多选4点、不在同一条直线上,此时再添加任意一个点,则一定出现3点一线。题目答案:2880题目解析:圆排列问题。5名大陆选手的排列方案数为:5!5名港澳选手安排在大陆选手之间的5个空位的排列方案数为:5!总的排列方案数为:5!×5!。但每位选手左边相邻的选手均相同,为重复方案。最终结果为:阅读程序#include<iostream>usingnamespace..

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

问题求解

NOIP 2012 年普及组初赛试题整理「建议收藏」题目答案:

5

题目解析:

贪心法。构造出最坏情况下至多选4点、不在同一条直线上,此时再添加任意一个点,则一定出现3点一线


NOIP 2012 年普及组初赛试题整理「建议收藏」

题目答案:

2880

题目解析:

圆排列问题。

5名大陆选手的排列方案数为:5 ! 
5名港澳选手安排在大陆选手之间的5个空位的排列方案数为:5 ! 
总的排列方案数为:5 ! × 5 ! 。

但每位选手左边相邻的选手均相同,为重复方案。
最终结果为:5! \times 5! \div 5 = 2880


阅读程序

#include <iostream>
using namespace std;
int n, i, j, a[100][100];
int solve(int x, int y){
    int u, v;
    if (x == n)return a[x][y];
    u = solve(x + 1, y);
    v = solve(x + 1, y + 1);
    if (u > v)
        return a[x][y] + u;
    else
        return a[x][y] + v;
}
int main(){
    cin>>n;
    for (i = 1; i <= n; i++)
        for (j = 1; j <= i; j++)
            cin>>a[i][j];
    cout<<solve(1, 1)<<endl;
    return 0;
}

输入:

5
2
-1 4
2 -1 -2
-1 6 4 0
3 2 -1 5 8

输出:________

题目答案:

14

题目解析:

这个程序是在找一条从 (1,1) 到 (n,x)(1≤x≤n)开始的和最大的路径,每次只能从 (i, j) 走到 (i+1, j) 或 (i+1, j+1)。


完善程序

NOIP 2012 年普及组初赛试题整理「建议收藏」

#include<iostream>
using namespace std;
const int SIZE = 100;
int x[SIZE], y[SIZE], f[SIZE];
int n, i, j, max_f, ans;
int main(){
    cin>>n;
    for (i = 1; i <= n; i++)
        cin >> x[i] >> y[i];
    max_f = 0;
    for (i = 1; i <= n; i++){
        f[i] =①;
        for (j = 1; j <= n; j++){
            if (x[j] < x[i] && ②)
                ③;
        }
        if (④){
            max_f = f[i];
            ⑤;
        }
    }
    for (i = 1; i <= n; i++)
        cout<<f[i]<<endl;
    cout<<ans<<endl;
}

填空④: f[i] >= max_f

题目解析:

若填 f[i] > max_f ,则当战斗力并列时不会更新最大值,题目要求为战斗力相同时,输出最大的编号,所以填f[i] >= max_f


NOIP 2012 年普及组初赛试题整理「建议收藏」

#include<iostream>
#include<cstring>
using namespace std;
const int SIZE = 25;
bool used[SIZE];
int data[SIZE];
int n, m, i, j, k;
bool flag;
int main(){
    cin>>n>>m;
    memset(used, false, sizeof(used));
    for (i = 1; i <= m; i++){
        data[i] = i;
        used[i] = true;
    }
    flag = true;
    while (flag){
        for (i = 1; i <= m-1; i++)cout<<data[i]<<"";
        cout << data[m] << endl;
        flag =①;
        for (i = m; i >= 1; i--){
            ②;
            for (j = data[i]+1; j <= n; j++)
                if (!used[j]){
                    used[j] = true;
                    data[i] =③;
                    flag = true;
                    break;
                }
            if (flag){
                for (k = i+1; k <= m; k++)
                    for (j = 1; j <=④; j++)
                        if (!used[j]){
                            data[k] = j;
                            used[j] = true;
                            break;
                        }
                ⑤;
            }
        }
    }
}

NOIP 2012 年普及组初赛试题整理「建议收藏」 

题目解析:

通过枚举的方式,输出排列。

空①,初始化标志变量 flag = false
空②,从最后一个位置的数字开始,将data[i]设置为未使用,used[data[i]] = false
空③,将位置i设置为数j
空④,枚举1~n所有可选数字,n
空⑤,枚举到一组方案,跳出for (i = m; i >= 1; i–)进行输出,break


版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/172078.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月22日 上午11:00
下一篇 2022年8月22日 上午11:16


相关推荐

  • Java基于Redis实现分布式锁

    Java基于Redis实现分布式锁分布式锁可以基于很多种方式实现 比如 zookeeper redis 不管哪种方式 他的基本原理是不变的 用一个状态值表示锁 对锁的占用和释放通过状态值来标识 一 为什么 Redis 可以方便地实现分布式锁 1 Redis 为单进程单线程模式 采用队列模式将并发访问变成串行访问 且多客户端对 Redis 的连接并不存在竞争关系 2 Redis 的 SETNX 命令可以方便的实现分布式锁 setN

    2026年3月20日
    3
  • OpenClaw高效使用指南:从精选技能安装到MCP配置的自动化办公实践

    OpenClaw高效使用指南:从精选技能安装到MCP配置的自动化办公实践

    2026年3月13日
    3
  • 微服务架构(java环境&tomcat)

    微服务架构(java环境&tomcat)

    2021年5月28日
    102
  • 白盒测试的几种覆盖方法:语句覆盖、判定覆盖、条件覆盖、判定/条件覆盖、组合覆盖和路径覆盖详解

    白盒测试的几种覆盖方法:语句覆盖、判定覆盖、条件覆盖、判定/条件覆盖、组合覆盖和路径覆盖详解文章转自 http www 51testing com html 44 n 3713444 html 白盒测试用例设计的一个很重要的评估标准就是对代码的覆盖度 一说到覆盖 大家都感觉非常熟悉 但是常见的覆盖都有哪些 各自有什么优缺点 在白盒测试的用例设计中我们应该如何自如地运用呢 今天小编就为大家总结了一下几种常见的覆盖以及各自的优缺点 白盒测试中常见的覆盖有六种 语句覆盖 判定覆盖 条

    2026年3月18日
    1
  • 阿里巴巴主流数据库连接池Druid入门

    阿里巴巴主流数据库连接池Druid入门一.数据库连接池的必要性(一).传统数据库连接模式的的步骤1.在主程序中创建连接2.进行sql操作3.关闭数据库连接(二).传统数据库连接模式存在的问题1.浪费时间:每次连接时都要验证登录和将conn加载到内存,2.不能大规模的访问数据库:当数据库访问人数过多时,占用大量系统资源,会导致服务器崩溃3.存在内存泄漏问题:每次连接都需要断开连接,如果不断开,程序运行结束,会有创建的连接对象存在内存中一直无法关闭,就会导致java内存…

    2022年7月23日
    14
  • pandownload激活码_pandownload账号

    pandownload激活码_pandownload账号yunfile网盘是国内的一个免费网盘,很多网站博客都会使用yunfile网盘的外链。但是该网盘广告多,等待时间长,免费用户只能一次下载一个文件,而且不能用迅雷等下载软件来下载,只能用IE,Chrome,Firefox等浏览器下载,下载速度又极其缓慢。但是有时候我们又不得不在该网盘下载文件,这个时候有一个yunfile网盘会员账号就可以解决上面所说的问题了。有求yunfile会员账号的朋友…

    2025年9月25日
    10

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号