当前位置: 首页 > article >正文

每日刷题(算法)

我们N个真是太厉害了

思路:

我们先给数组排序,如果最小的元素不为1,那么肯定是吹牛的,我们拿一个变量记录前缀和,如果当前元素大于它前面所有元素的和+1,那么sum+1是不能到达的值。

代码:

#define _CRT_SECURE_NO_WARNINGS
#include<bits/stdc++.h>
#include<algorithm>
#define int long long
#define pb push_back
#define TEST int T; cin >> T; while (T--)
#define ios ios::sync_with_stdio(false), cin.tie(nullptr), cout.tie(nullptr)
#define lowbit(x) x&(-x)
#define pll pair<int,int>
const int N = 1e6 + 30;
const int M = 1e3 + 10;
const int inf = 512785182741247112;
const int mod = 1e9 + 7;
using namespace std;


void solve()
{
    int n;
    cin >> n;
    vector<int>a(n + 1);
    for (int i = 1; i <= n; i++) cin >> a[i];
    sort(a.begin() + 1, a.end());
    if (a[1] != 1) {
        cout << 1 << '\n';
        return;
    }
    int sum = 1;
    for (int i = 2; i <= n; i++) {
        if (a[i] > sum + 1) {
            cout << sum + 1 << '\n';
            return;
        }
        sum += a[i];
         if (sum >= n) {
            cout << "Cool!\n";
            return;
        }
    }
    cout << "Cool!\n";
    
}
signed main() {
    ios; TEST
        solve();
    return 0;
}

折返跑

思路:

其实是一个组合数学的题目,我们只要规定每个折返至少挪一米,那么剩下的就可以随便安排,就是一个C(可用的距离,折返次数)就是答案,我们可以预处理一下1到1e6的阶乘。

代码:

#define _CRT_SECURE_NO_WARNINGS
#include<bits/stdc++.h>
#include<algorithm>
#define int long long
#define pb push_back
#define TEST int T; cin >> T; while (T--)
#define ios ios::sync_with_stdio(false), cin.tie(nullptr), cout.tie(nullptr)
#define lowbit(x) x&(-x)
#define pll pair<int,int>
const int N = 1e6 + 30;
const int M = 1e3 + 10;
const int inf = 512785182741247112;
const int mod = 1e9 + 7;
using namespace std;

int f[N], a[N], sum[N];
int C(int n, int m) {
    if (n < m) return 0;
    if (m == 0) return 1;
    return f[n] * qpow(f[n - m] * f[m], mod - 2, mod) % mod;
}
void solve()
{
    int n, m;
    cin >> n >> m;
    cout << C(n - 2, m - 1) << '\n';

}
signed main() {
    f[0] = 1;
    f[1] = 1;
    for (int i = 2; i <= 1e6; i++) f[i] = f[i - 1] * i % mod;
    ios; TEST
        solve();
    return 0;
}

好好好数

思路:

直接将n变成k进制数,发现答案就是最大的因为,当k为1时,直接输出1。

代码:

#define _CRT_SECURE_NO_WARNINGS
#include<bits/stdc++.h>
#include<algorithm>
#define int long long
#define pb push_back
#define TEST int T; cin >> T; while (T--)
#define ios ios::sync_with_stdio(false), cin.tie(nullptr), cout.tie(nullptr)
#define lowbit(x) x&(-x)
#define pll pair<int,int>
const int N = 3e5 + 30;
const int M = 1e3 + 10;
const int inf = 512785182741247112;
const int mod = 998244353;
using namespace std;

vector<int>f;
int n, k;
void solve()
{
    cin >> n >> k;
    if (k == 1) {
        cout << 1 << '\n';
        return;
    }

    int ans = 1;
    while (n) {
        ans = max(ans, n % k);
        n /= k;
    }
    cout << ans << '\n';

    
}

signed main() {

    ios; TEST
        solve();
    return 0;
}


http://www.kler.cn/a/311089.html

相关文章:

  • 文件夹被占用了无法删除怎么办?强制粉碎文件夹你可以这样操作
  • Linux 函数在多个地方被同时调用时,函数中的变量如何管理,确保互不影响
  • 十三、注解配置SpringMVC
  • 使用kalibr_calibration标定相机(realsense)和imu(h7min)
  • 【Java SE】接口类型
  • 软件测试面试题(800道)【附带答案】持续更新...
  • 开发一个电商API接口的步骤!!!
  • microchip中使用printf给AVR单片机串口重定向
  • Redis实现发布/订阅功能(实战篇)
  • uniapp中实现<text>文本内容点击可复制或拨打电话
  • tronado websocket
  • Java基础:Api 文档注释,字符串种类,String字符串创建,特点及常用方法
  • 【洛谷】P1546 [USACO3.1] 最短网络 Agri-Net 的题解
  • SqlServer自定义类型的使用
  • 【数据结构-一维差分】力扣1893. 检查是否区域内所有整数都被覆盖
  • 无人机滑环的核心特点及其应用分析
  • [论文笔记] LLM端侧小模型篇——1、剪枝量化的latency
  • MySQl篇(基本介绍)(持续更新迭代)
  • Leetcode—删除有序数组的重复项
  • 408算法题leetcode--第七天
  • Llama 3.1 大模型指令微调提升中文能力
  • 【系统架构设计师-2019年真题】案例分析-答案及详解
  • Scikit-learn 学习笔记
  • 尚品汇-秒杀商品存入缓存、Redis发布订阅实现状态位(五十一)
  • 全球首个!复旦大学冯建峰团队开发数字孪生脑平台,具备 860 亿神经元规模
  • 旷视轻量化网络shufflenet算法解读