萌新联赛第(三)场

C题

这道题用暴力去写想都不要想,一定超时,于是我们需要优化,下面是思路过程:

如图,本题只需找到x的因数个数和(n-x)的因数个数,这两个相乘,得到的就是对于这个x来说组合的个数,且x的取值为1~n,由题n取不到。

代码:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N=100005;
int num[N];//记录各个数字的因数个数
int main(){
    int n,ans=0;//ans方案种数
    cin>>n;
    for(int i=1;i<n;i++){  //遍历1~n的数字
        for(int j=1;j*j<=i;j++){  //求其因数个数
            if(i%j==0){
                num[i]++;  //由题知,A,B,C,D这四个数是有序的,因此每次判断都会有两个因数
                if(j*j!=i)num[i]++; //所以下面要+1,除非这两个数相等只需加1次
            }
        }
    }
    for(int i=1;i<n;i++){  //遍历和为n,加数所有可能的取值
        ans+=num[i]*num[n-i];//因数个数相乘即得对应的组合数
    }
    cout<<ans;
    return 0;
}

H题

本题乍一看很简单,就是求出每一个子集的和即可,但如何不重不漏的求出每一个集合我是真的不会,好的,换思路,利用贪心思想,将原集合排序,从第一个最小的数开始,逐步扩展可以表示的子集和范围,同时找到第一个无法表示的整数。因为已经排好序了,所以对于元素个数相同的集合来说,总是最前面的最小,而且代码的判断条件是ai>sum+1,那么sum + 1 就无法被表示,因为当前的子集和范围无法覆盖到 sum + 1,直接输出sum+1,相反,如果ai<=sum+1,说明当前子集很可能已经覆盖了sum+1,让ai与sum+1比较是否可以覆盖,同时也可以避免出现不同子集因元素个数的不同造成对应的子集和大小不同问题,因为如果ai>sum+1说明ai一定很大,那么毫无疑问元素多的集合的和一定比元素少的集合的和大,这样我们就可以实现由小到大逐步扩展子集和范围。

代码如下:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N=100005;
long long a[N];
int main(){
    int n;
    cin>>n;
    for(int i=0;i<n;i++){
        cin>>a[i];
    }
    sort(a,a+n); //由小到大逐步排序
   long long sum=a[0]; //记录当前子集和的最大值
    for(int i=1;i<n;i++){
        if(sum+1<a[i]){   //比较当前子集和+1是否可以被下一个集合元素表示出来
            cout<<sum+1; //如果可以,输出,结束
            return 0;
        }
        else sum+=a[i]; //否则,继续累加
    }
    cout<<sum+1; //如果一直没在上面结束的话,此时sum代表全集的和,+1即是答案
    return 0;
}

D题

对于这道题需要知道一个知识点:

x+y=(x&y)+(x|y)

根据位运算性质,x&y和x|y满足:(x&y)&(x|y)=x&y

本题思路:

由于x&y=a;说明x>=a,y>=a,则x+y>=2a,即s>=2a------第一个判断条件

又由x&y=a,x+y=s和上述知识点知x|y=s-a。因此,a&(s-a)=a------第二个判断条件

如果第一个不满足的话,直接输出NO,程序结束,否则,继续判断第二个条件。

这样做的好处是不用一一枚举出来x,y的值

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main(){
    int t;
    long long a,s;
    cin>>t;
    while(t--){
        cin>>a>>s;
        if(s<2*a){  //首先判断
            cout<<"No"<<endl;
        }
        else{  //继续深入判断
            if((a&(s-a))==a) cout<<"Yes"<<endl;
            else cout<<"No"<<endl;
        }
    }
    return 0;
}

比赛地址:https://www.nowcoder.com/acm/contest/110544。【邀请码:666666】

相关推荐
为何创造硅基生物2 分钟前
独占指针的创建std::make_unique 本身自带堆出现
c++
JieE21214 分钟前
JS 到底有多少种数据类型?从ECMA规范到内存本质,一文彻底搞懂
javascript·数据结构·面试
kyle~14 分钟前
ROS 2 与 Isaac Sim 联合仿真(一)体系架构、环境选型与基础通信闭环
c++·机器人·nvidia·仿真·ros2
努力努力再努力wz35 分钟前
【内存管理与高并发内存池系列】从 mmap 到 malloc:文件映射、匿名映射与 glibc 内存分配机制详解
linux·c语言·数据结构·数据库·c++·qt·链表
八解毒剂1 小时前
数据结构-平衡二叉树——对二叉搜索树的优化
数据结构·c++·算法
运行时记录1 小时前
别再手动写提示词了 — SkillOpt 让技能文档自己进化
算法
起床困难户5751 小时前
条款20:协助完成返回值优化
c++
啦啦啦啦啦zzzz2 小时前
算法总结(二分查找、双指针)
c++·算法
qq_8573058192 小时前
python语法
开发语言·python·算法
DXM05212 小时前
第9期|从机器学习到深度学习:AI遥感解译的进化逻辑
人工智能·算法·计算机视觉