首页 > 编程语言 >NOC 2022 初中组选择和编程题题解

NOC 2022 初中组选择和编程题题解

时间:2023-04-15 22:45:24浏览次数:54  
标签:1.1 int 题解 1200 NOC secretStr 2022 tmpRes stepMove

NOC 2022 初中组选择题和编程题题解

注意:本文有几个问题:

  1. 部分题目我也不确定答案,而且我水平不行,有些题目我还真不会,大家就把我的答案当个参考吧。
  2. 目前有一大半的题目因为作者比较懒,暂时没写,空在那儿,可以下载原题自己做做。

1 初中组选拔赛

原题链接,提取码:efy6

1.1 选择题部分

1.1.1 A。C++ 中,main() 函数有且仅有一个。

1.1.2 D。A 选项 \((42.8)_{16}=(66.5)_{10}\),B 选项 \((66.5)_{10}\),C 选项 \((1024.8)_{8}=(66.5)_{10}\),D 选项 \((1000011.1)_{2}=(67.5)_{10}\)。

1.1.3 D。C++ 中 if (expression) 里的 expression,只要不是 0 就是真,所以 A、B 和 C 都是等价的,只有 D 不一样。

1.1.4 A。这道题目要反过来思考,问有多少个含有 2 的数字,那就算出有多少个不含 2 的数字。1 到 2000 之间,共有 \(9*9*9*2-1=1457\) 个不含 2 的数字(减去 1 是因为多了一个 0),那就有 \(2000-1457=543\) 个含有 2 的数字,再加上都含有 2 的 2001 到 2022,有 22 个数字,总共 565 个。

1.1.5 A。C 和 D 肯定不用多说,B 因为 C++ 里从左向右计算,++ 晚于 * 运算,所以结果依然是 4。A 选项中,++ 早于 *,结果是 6。

1.1.6 B。做个简单的计算就可以发现,第 n 次循环的结果就是 \(2^{n}-1\),因此第 50 次循环的结果就是 \(2^{50}-1\)。

1.1.7 B。做个模拟,就能发现 B 的顺序是没办法实现的。

1.1.8 C。自行查找各种排序算法的时间复杂度表格。

1.1.9 A。牢记 C++ 的数组下标是从 0 开始的,所以该值之前的行数就是 i,列数就是 j,结果也就是 \(i*n+j\)。

1.1.10 C。这个我真的不知道了,到网上查了一圈也没有结果,就蒙了一个,有懂的同学请留言指教。

1.1.11 C。这道读程很简单了,cnta 就是字符串里英文字母的数量,cntn 就是数字的数量,getline() 可以读入空格,所以 D 是正确的,但是可能还有其他特殊字符,所以 cnta + cntn 不一定是总字符数。

1.1.12 D。这个程序先读入一个字符串,然后统计里面各个字符的输入次数,输出字典序第一个只出现了一次的字符,如果没有,就输出 no。那么很明显了,它一不会输出个数,二不会输出多个,至于 B 的情况更不可能,只有 D 正确。

1.1.13 B。递归函数,数据比较小,手动模拟即可。最终会形成一棵二叉树,关键是找到遍历的顺序(先序遍历),按序输出就行。大致如图,结点右边括号里的数字是顺序,连接线旁边的是返回结果。最后别忘了还有个返回值输出。

                     6(1)     --- 最终结果:3
                    2/  \1
                  3(2)  2(5)
                 1/  \1
                1(3) 0(4)

(我尽力了,唉。)

1.1.14 A。这道题循环判断,分别将每一个数和所有数一次比较,如果前者小于后者,或者前后相等且前者下标比较大,就给计数器 cnt 加一。很容易发现,因为所有数据都是相等的,所以每次结果都是 i - 1,当 cnt == m 时,也就是 \(i-1=m\),\(i=m+1\)。

1.1.15 这道题目和上面那题的程序是一样的,但是给的样例变成了升序且不相等。这时候 cnt 加一的条件就变成前一个了,这回 cnt 的结果就成了 n - m,也就是 \(i=n-m\)。

1.2 编程题部分

1.1.16 第一道打卡题,相当简单,不仔细说了,自行查看代码即可。

#include <iostream>

using namespace std;
int stepMove;
string secretStr;

int main() {
    cin >> stepMove >> secretStr;
    stepMove = stepMove % 26;
    char tmpRes;
    for (int i = 0; i < secretStr.length(); i++) {
        tmpRes = secretStr[i] - stepMove;
        if (secretStr[i] >= 'A' && tmpRes < 'A') {
            tmpRes = 'Z'- ('A' - tmpRes);
        }
        if (secretStr[i] >= 'a' && tmpRes < 'a') {
            tmpRes = 'z'- ('a' - tmpRes);
        }
        cout << tmpRes;
    }
}

1.1.17 这道题目粗略估算 \(O(n^{3})\) 勉强能过,所以就用了暴力解法加上一点点优化,希望能拿到大部分分。这个程序就仅供参考了。

#include <iostream>

using namespace std;
int matches;
int students;
int matchResult[1200][1200];
int rankList[1200][1200];
int beKilled[1200];
int killedCnt;

int main() {
    cin >> matches >> students;
    for (int i = 1 ; i <= matches; i++) {
        for (int j = 1 ; j <= students; j++) {
            cin >> matchResult[i][j];
            rankList[matchResult[i][j]][i] = j;
        }
    }
    bool keepWin;
    for (int i = 1; i <= students; i++) {
        for (int j = 1; j <= students; j++) {
            if (i == j) {
                continue;
            }
            if(beKilled[i] == j) {
                break;
            }
            keepWin = true;
            for (int k = 1; k <= matches; k++) {
                if (rankList[i][k] > rankList[j][k]) {
                    keepWin = false;
                    break;
                }
            }
            if (keepWin) {
                killedCnt++;
                beKilled[j] = i;
            }
        }
    }
    cout << killedCnt;
    return 0;
}

1.1.19 TBC...

1.1.20 TBC...

2 初中组决赛

原题链接,提取码:KWfw

2.1 选择题部分

TBC...

2.2 编程题部分

TBC...

标签:1.1,int,题解,1200,NOC,secretStr,2022,tmpRes,stepMove
From: https://www.cnblogs.com/r3vxax/p/17322128.html

相关文章

  • 超级码力初赛第三场 最大公倍数 题解
    题目描述小栖有一个区间[a,b],他准备从中取三个数,他想知道如何取才能使得它们的最小公倍数最大请直接告诉小栖最小公倍数是多少。1<=a<b<=5000b-a>=2示例示例1:输入:a=3,b=6输出:60样例解释:4,5,6的最小公倍数是60来源:九章算法解题思路每三个数为一......
  • [NISACTF 2022]babyserialize
    [NISACTF2022]babyserialize<?phpinclude"waf.php";classNISA{public$fun="show_me_flag";public$txw4ever;publicfunction__wakeup(){if($this->fun=="show_me_flag"){hint();......
  • windows pip问题解决(working)
    当pip无法起效时,尝试python-mpippython-mpip会使用您指定为python的Python解释器来执行pip。因此,/usr/bin/python3.7-mpip表示您正在执行位于/usr/bin/python3.7的解释器的pip。如果您不熟悉这个标志以及它是如何工作的,您可以阅读有关-m的文档......
  • 2022 Shanghai Collegiate Programming Contest B
    知识点:差分约束Link:https://codeforces.com/gym/103931/problem/B。被卡SPFA了呃呃。一看出题人是这个人:如何看待SPFA算法已死这种说法?-fstqwq的回答-知乎,那没事了。简述给定参数\(n,q\),表示有一个长度为\(n\)的合法括号序列,且有\(q\)组限制。每组限制均为......
  • git 遇到的CApath: none问题解决
    在适应git时,遇到了如下问题。fatal:unabletoaccess'https://github.com/brunosimon/folio-2019.git/':errorsettingcertificateverifylocations: CAfile:D:/明月下/Git/mingw64/ssl/certs/ca-bundle.crtCApath:none第一反应是查找这个文件是什么,在不在。首先这......
  • [P4317 花神的数论题]题解
    P4317花神的数论题【数位DP】题目描述最开始其实没有什么想法第一次遇见数位dp求相乘的题想就按照常规做法来做,但不知道如何去处理*于是写了一个错误的代码//当前枚举到第id位,前面的1的个数为sum,是否达到上限limitlldfs(intid,intsum,intlimit){//1.出口if(id==......
  • CF1592F2 题解
    题意传送门给定一个\(n\)行\(m\)列的目标矩阵,矩阵元素只有W或B,并且你有一个初始矩阵,元素全为W。现在你可以矩阵实施以下操作:使用一块钱,选定一个包含\((1,1)\)的子矩阵,把矩阵中的元素全部反转(W变B,B变W)。使用三块钱,选定一个包含\((n,1)\)的子矩阵,把矩阵......
  • Luogu_P1613 跑路 题解
    发现和最短路差不多,不过不能朴素的跑最短路。考虑对于每两个相隔\(2\)的整数次幂的点建边,在这个新图上跑最短路就是答案。设\(f_{i,j,k}\)表示从点\(i\)跳\(2^k\)步能否到点\(j\),转移方程就是一个普通的倍增。如果点\(i\)和点\(j\)可以一步到达,那么就在新图上建一条......
  • ABC249F 题解
    前言题目传送门!更好的阅读体验?很好玩的贪心。思路如果第\(i\)次操作为覆盖操作,那么\(1\simi-1\)次操作都是无效的,原因显然。这启示我们从后往前扫(前面的会被忽略,后面的不会啊!)。在此基础上,就是分类讨论一下(假设当前的最大答案为\(sum\)):当前操作是覆盖操作:如果不......
  • 【题解】Tree MST
    题面给定一棵\(n\)个节点的树,现有有一张完全图,两点\(x,y\)之间的边长为\(w_x+w_y+dis_{x,y}\),其中\(dis\)表示树上两点的距离。求完全图的最小生成树。\(n\leq2\times10^5\)。题解???神秘借鉴支配对的思想,点分治后将树中点权替换为\(dep_i+w_i\),选择点权最小的一个......