IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> 【记录CF】Codeforces Round #774 (Div. 2) A~C 题解 -> 正文阅读

[C++知识库]【记录CF】Codeforces Round #774 (Div. 2) A~C 题解

目录

杂谈

A. Square Counting

B. Quality vs Quantity

C. Factorials and Powers of Two


杂谈

不得不说这场 cf 的时间真的很阴间,在菜和状态差的双重影响下毫无疑问直接掉大分。

这场的A题特别友好,属于看完题直接能签的那种;B题上来就想了个假思路,连WA两发,意识到问题之后改完思路,但没完全改完代码,又草率地交了,理所当然的又WA了一发,最后调整完索性算是过了;C题上来又想了个分情况的假算法,但后来发现情况分不完(<@_@>),在结束前半个小时发现好像直接暴力枚举也T不了,可惜最后还是没写出来。

赛后看了下同学的暴力代码,二进制枚举,这才回想起来寒假集训营也有一题用二进制枚举不同的组合,没想到这才补完题没多久就忘了(看来还是不够努力-O-)。

A. Square Counting

题目链接:Problem - A - Codeforces

题目大意:定义 n + 1 长度的序列中每个数是 [0, n) 或者是 n^2,序列所有元素的和为 s,求给定 n 和 s 的情况下,序列中是 n^2 的数的个数。(其中 s 是一定合法的值)

解题思路:因为 s 一定是合法值,那么如果 s 是大于等于?n^2?的数,那么一定有?\left \lfloor \frac{s}{n^2} \right \rfloor?个?n^2?的数;如果 s 小于?n^2,那么一定没有?n^2?这样的数。因此整合一下直接输出?\left \lfloor \frac{s}{n^2} \right \rfloor就好了。

AC代码:

#include <bits/stdc++.h>
#define lowbit(x) (x & -x)
#define mid (l + r >> 1)
 
using namespace std;
typedef long long ll;
const int INF = 0x3f3f3f3f;
const int mod = 1000000007;
 
int main(){
    //freopen("input.txt", "r", stdin);
    ios::sync_with_stdio(false);
    cin.tie(NULL);
    cout.tie(NULL);
    int t;
    cin >> t;
    while(t--){
        ll n, s;
        cin >> n >> s;
        cout << s / (n * n) << endl;
    }
    return 0;
}

B. Quality vs Quantity

题目链接:Problem - B - Codeforces

题目大意:判断给定的序列是否满足涂红色数的值之和大于涂蓝色数的值之和,且涂红色数的数量小于涂蓝色数的数量。其中涂色可以任意选择。

解题思路:对序列排个序,从最小的两个数的和开始与最大的一个数进行比较,每次左右各加上一个数,只要有一种状态下左边的和比右边的和小,那么这种状态就满足条件,就输出YES,如果每一种状态都不满足,就输出NO。

AC代码:

#include <bits/stdc++.h>
#define lowbit(x) (x & -x)
#define mid (l + r >> 1)

using namespace std;
typedef long long ll;
const int INF = 0x3f3f3f3f;
const int mod = 1000000007;
const int N = 200005;
ll a[N];

int main(){
    //freopen("input.txt", "r", stdin);
    ios::sync_with_stdio(false);
    cin.tie(NULL);
    cout.tie(NULL);
    int t;
    cin >> t;
    while(t--){
        int n;
        cin >> n;
        for(int i = 1; i <= n; i++) cin >> a[i];
        sort(a + 1, a + n + 1);
        ll sum1 = a[1], sum2 = 0;
        int flag = 0;
        for(int i = 2, j = n; i < j; i++, j--){
            sum1 += a[i];
            sum2 += a[j];
            if(sum1 < sum2){
                flag = 1;
                break;
            }
        }
        if(flag) cout << "YES" << endl;
        else cout << "NO" << endl;
    }
    return 0;
}

C. Factorials and Powers of Two

题目链接:Problem - C - Codeforces

题目大意:定义 powerful number 为?2^n?或?n!,求给定的数中能分成最少的不重复的 powerful number 的数之和的个数,如果不能分成若干个 powerful number 之和,输出 -1。

解题思路:首先打表发现阶乘要小于 10^{12},那么最多只会到?15!,那么可以预处理出前 15 个数的阶乘。然后通过二进制枚举的方式选择不同的阶乘组合进行求和 sum,然后在剩下的 n - sum 的值中找二进制中的 1 的个数就是剩下的还需要多少 2 的次幂的数,每种组合求出所需的 power number 的个数最后取最小值就是答案了。(由于?2^0?到?2^{n - 1}?可以表示任意一个 2^n - 1?以内的数,因此一个数一定能够分解成若干个不同的 powerful number 之和)

AC代码:

#include <bits/stdc++.h>
#define lowbit(x) (x & -x)
#define mid (l + r >> 1)

using namespace std;
typedef long long ll;
const int INF = 0x3f3f3f3f;
const int mod = 1000000007;
ll n, sum, cnt, ans;
ll fac[15 + 1];

void init(){
    fac[0] = 1;
    for(int i = 1; i <= 15; i++){
        fac[i] = fac[i - 1] * i;
    }
}

int main(){
    //freopen("input.txt", "r", stdin);
    ios::sync_with_stdio(false);
    cin.tie(NULL);
    cout.tie(NULL);
    init();
    int t;
    cin >> t;
    while(t--){
		cin >> n;
		ans = INF;
		for(int i = 0; i < (1 << 15); i++){
			sum = 0, cnt = 0;
			for(int j = 0; j <= 15; j++){
				if((i >> j) & 1){
				 	sum += fac[j];
				 	cnt++;
				}
			}
			ll res = n - sum;
			if(res >= 0){
			    while(res){
				    if(res & 1) cnt++;
				    res >>= 1;
			    }
                ans = min(ans, cnt);
			}
		}
		cout << ans << endl;
	}
    return 0;
}
  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-08 22:10:02  更:2022-03-08 22:14:22 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 11:16:32-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码