【笔试训练】day15

news2025/1/12 12:22:28

1.平方数

水题直接看代码

代码:

#define _CRT_SECURE_NO_WARNINGS 1
#include <iostream>
#include<math.h>
#include<algorithm>
using namespace std;
typedef long long ll;
int main() {
    ll x;
    cin >> x;
    ll a = sqrt(x);
    if (abs(a * a - x) < abs((a + 1) * (a + 1) - x)) {
        cout << a * a << endl;
    }
    else {
        cout << (a + 1) * (a + 1) << endl;
    }
    return 0;
}

2.分组

思路:

一眼二分。一般来说,遇到什么最大属性集合里面求最小都可以考虑用二分。

这题求人数最多的小组的人尽可能少。

我们将每一次分组情况都视为一次二分。每次二分的mid表示当前的所有分组中,拥有最多人数的组的人数。以此为基准,对所有的人进行分组,看能不能至少凑成m组,且这m组的每组最多人数不超过mid。

分组如何分呢?如果某一个声部的人数超过mid,我们就把超过的部分添加到新的一组去。如果人数小于或者等于mid,那就让他们一起为一组。

这样分可以得到以下结论:所有分组的最多人数不超过mid。且这样分组,组的数量是最少的。

 如果按最少分组的数量都能大于m,说明我一定不能能把这些分组拆成恰好m个

 如果按最少分组的数量<m。无非就是从每组割一点人出来组成新的一组嘛。比如让一部分人一个人一组嘛。

我们把能分组成功的mid都放在右边。不能分组成功的都放在左边。

等到二分结束。r一定是在所有可以分组成功情况中的最左边。也就是,r是所有成功分组情况中,组内人数最多的值里面最小的。

此外如果r没有动,那就说明根本就没有mid可以分组成功。

代码:

#include <iostream>
#include<algorithm>
#include<unordered_map>
using namespace std;
const int N=1e5+10;
unordered_map<int,int> mp;
int mr;
int n;
int m;

bool check(int mid){//mid为人数最多的数量
   if(mr<mid)return false;
    int res=0;
    for(auto it:mp){
       if(it.second>mid){
           res+=(it.second+mid-1)/mid;//向上取整
       }else if(it.second<=mid){
           res++;
       }
    }
    if(res>m)return false;
    return true;
}

int main() {
   cin>>n>>m;

   for(int i=1;i<=n;i++){
     int x;
     cin>>x;
     mp[x]++;
     mr=max(mr,mp[x]);
   }

   int l=0,r=mr+1;
   while(l+1!=r){
    int mid=(l+r)>>1;
    if(check(mid))r=mid;
    else l=mid;
   }
   if(r!=mr+1)cout<<r<<endl;
   else cout<<-1<<endl;
   return 0;
}

3.拓扑排序

思路:拓扑排序的板子。先存一下边,再存一下每个点的入度。遍历每一条边,遍历的同时删除当前边,即入度减减。如果这个点的入度为0了,就入队列。拓扑排序保证,越早入队列的点,一定越在路径的前面。最后看一下是否每个点都入队列就行。

代码:

#include <iostream>
#include<vector>
#include<queue>
using namespace std;
const int N=2e5+10;
int n,m;
int d[N];
vector<int> ans;

bool topu(vector<vector<int>>& g){
   queue<int> q;
   for(int i=1;i<=n;i++){
    if(d[i]==0){
        ans.push_back(i);
        q.push(i);
    }
   }

   while(!q.empty()){
      int t=q.front();
      q.pop();
      //cout<<t<<" kkk ";
  
      for(auto it:g[t]){
          d[it]--;
          if(d[it]==0){
            q.push(it);
            ans.push_back(it);
          }
      }
   }
   //cout<<ans.size()<<endl;
   if(ans.size()==n)return true;
   return false;
}

int main() {
   cin>>n>>m;
   vector<vector<int>> g(n+1);
   while(m--){
    int a,b;
    cin>>a>>b;
    g[a].push_back(b);
    d[b]++;
   }
   if(!topu(g))cout<<-1<<endl;
   else {
    for(int i=0;i<ans.size();i++){
        if(i!=ans.size()-1)cout<<ans[i]<<" ";
        else cout<<ans[i];
    }
   }
   
   return 0;
}

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1635646.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

新冠轻症康复者病毒仍在复制 新冠抗病毒药先诺欣和乐睿灵怎么选?

近日,国家疾控局发布的通知显示,当前我国新冠疫情持续保持低水平波浪式流行态势,但新冠病毒仍在变异,疫情仍存在一定的反复性。“五一”假期人员流动性上升和聚集性活动增加,可能加大疫情传播风险,防控任务艰巨复杂。 新冠病毒该怎么防?感染新冠后又当如何用药?对新冠病毒的…

C语言指针和数组的一些笔试题

文章目录 前言一、一维数组二、字符数组-1三、字符数组-2总结 前言 C语言指针和数组的一些笔试题 一、一维数组 #include <stdio.h> int main() {int a[] { 1,2,3,4 };printf("%d\n", sizeof(a));printf("%d\n", sizeof(a 0));printf("%d\n…

LLM之RAG理论(十一)| 面向生产的RAG应用程序的12种调整策略指南

本文对文本RAG涉及到的主要12种关键“超参数”进行简单总结&#xff0c;主要包括摄取阶段&#xff08;数据清洗、数据分块、embedding模型选择、元数据过滤、多重索引和索引算法&#xff09;和推理阶段【检索和生成】&#xff08;查询转换、检索参数、高级检索策略、重排序、大…

Java中优雅实现泛型类型的强制转换

在Java中经常遇到将对象强制转换成泛型类的情况&#xff1a; Map<String, Object> data Map.of("name", "XiaoMing","age", 17,"scores", List.of(80, 90, 70) );List<Integer> scores (List<Integer>) data.get…

二维码门楼牌管理应用平台:智慧城市的新引擎

文章目录 前言一、数据管理&#xff1a;打造智慧城市的数据基石二、数据应用&#xff1a;推动城市管理的智能化升级三、展望未来&#xff1a;构建更加智慧的城市管理体系 前言 随着城市化的快速推进&#xff0c;城市管理面临着前所未有的挑战。二维码门楼牌管理应用平台作为一…

郡望是一个什么性质的概念

顾名思义&#xff0c;郡望就是某郡中的望族。 别看现在听起来没什么感觉&#xff0c;在古代却是一个沉甸甸的庞然大物&#xff0c;是标志贵贱的&#xff0c;决定了个人&#xff0c;家庭和家族的未来。 自秦朝实行郡县制&#xff0c;直到唐朝废郡&#xff0c;郡做为一级或州管的…

mysql-sql练习-5-行列互转

目录 成绩单 简单互转 需求 多行转多列 分组 判断 聚合 理解 分组 合并 逆向需求 多列转多行 输出 合并 abc 去重 合并 拆分 需求 建表 多行转多列 逆向需求 多列转多行 拆分 按长度 拆分 按个数 成绩单 简单互转 需求 多行转多列 分组 判断 聚合 with tmp as(--…

Ubuntu 24.04 LTS (Noble Numbat) 正式版发布

Ubuntu 24.04 LTS (Noble Numbat) 正式版发布 Canonical 的第 10 个长期支持版本在性能工程、企业安全和开发人员体验方面树立了新标准 请访问原文链接&#xff1a;Ubuntu 24.04 LTS (Noble Numbat) 正式版发布&#xff0c;查看最新版。原创作品&#xff0c;转载请保留出处。…

带环链表及例题

环形链表&#xff0c;链表中的尾节点指向链表中的某个节点导致形成循环的链表。 通过图可以这样表示。 我们一般采用快慢指针的方式解决带环链表的题目&#xff0c;下面直接上例题 环形链表 力扣链接&#xff1a; . - 力扣&#xff08;LeetCode&#xff09; 让我们判断一个…

38 线程互斥

目录 1.问题 2.互斥相关概念 3.互斥量 4.互斥量接口 5.修改买票代码 6.互斥量原理 7.锁的封装 8.可重入和线程安全 1. 问题 用一个模拟抢票过程的程序引出本节话题&#xff0c;如果有1000张票&#xff0c;设为全局变量&#xff0c;生成3个线程每隔一秒抢一张票&#xff0c;如…

奥比中光Astra RGBD ROS1配置(乐视RGBD)

早年买了一款乐视RGBD一直落灰&#xff0c;最近做一个机器人项目想重新使用起来。发现官方给的RGBD包和github上面的ros_astra_camera包并不能很好的驱动这款相机。研究了一下进行补足。 最终的结果是彩色&#xff0c;红外以及深度退昂均能实时读取。具体过程如下&#xff1a; …

【LeetCode】---剑指Offer 31.栈的弹出压入序列

一、题目描述&#xff1a; 二、算法原理&#xff1a; 核心思想&#xff1a; 入栈的栈顶元素跟出栈序列进行匹配&#xff0c;入一个匹配一个。注意&#xff1a;结束的标志就是入栈序列走完了。 三、代码实现&#xff1a; class Solution { public:/*** 代码中的类名、方法名、…

每天五分钟深度学习:如何理解梯度下降算法可以逼近全局最小值?

本文重点 上节课程中,我们已经知道了逻辑回归的代价函数J。要想最小化代价函数,我们需要使用梯度下降算法。 梯度下降算法地直观理解: 为了可视化,我们假设w和b都是单一实数,实际上,w可以是更高地维度。 代价函数J是在水平轴w和b上的曲面,因此曲面的高度就是J(w,b)在…

低功耗数字IC后端设计实现典型案例| UPF Flow如何避免工具乱用Always On Buffer?

下图所示为咱们社区低功耗四核A7 Top Hierarchical Flow后端训练营中的一个案例&#xff0c;设计中存在若干个Power Domain&#xff0c;其中Power Domain2(简称PD2)为default Top Domain&#xff0c;Power Domain1&#xff08;简称PD1&#xff09;为一个需要power off的domain&…

21 如何进行高保真压测和服务扩容?

在后台架构中&#xff0c;压测非常常见&#xff0c;也是必须的工作。它能够帮我们发现微服务架构中的性能瓶颈&#xff0c;以及知道构建的微服务能承载的流量极限值。 但实际情况是&#xff0c;很多压测并不能发现瓶颈点和微服务所能承载的真实流量极限值。一方面是因为压测时…

【专篇】DDR4 SDRAM-01总体介绍

概念 DDR4 SDRAM(Double-Data-Rate Fourth Generation Synchronous Dynamic Random Access Memory)是一种先进的高性能存储器规格,是DDR3 SDRAM的后续产品。自2011年首次由三星电子制造并公布以来,它已经成为现代计算机系统中广泛采用的内存标准。 主要特点: 更高带宽: DD…

Spring6 当中的 Bean 循环依赖的详细处理方案+源码解析

1. Spring6 当中的 Bean 循环依赖的详细处理方案源码解析 文章目录 1. Spring6 当中的 Bean 循环依赖的详细处理方案源码解析每博一文案1.1 Bean的循环依赖1.2 singletion 下的 set 注入下的 Bean 的循环依赖1.3 prototype下的 set 注入下的 Bean 的循环依赖1.4 singleton下的构…

什么是人才测评系统?

人才测评系统是一个整体的框架&#xff0c;里面有很多个部分构成&#xff0c;既有常见的人才测评方法&#xff0c;也包含有招聘的目的。随着科学研究的不断深入&#xff0c;人才测评系统已经变得更加完善&#xff0c;将现代心理学和管理学知识吸纳到人才测评理论中来&#xff0…

OpenAI神秘搞事,GPT-4.5默默上线?推理碾压GPT-4网友震惊,奥特曼笑而不语

【新智元导读】就在昨夜&#xff0c;整个AI社区都被一个神秘大模型震撼到了&#xff1a;它名为gpt2-chatbot&#xff0c;性能直接超越很多开源模型和GPT-4&#xff01;网友们展开猜测&#xff0c;有说它是GPT-4.5的&#xff0c;有说是GPT-5的&#xff0c;还有人猜它是GPT-4Q*&a…

深度学习论文: MobileNetV4 - Universal Models for the Mobile Ecosystem及其PyTorch实现

深度学习论文: MobileNetV4 - Universal Models for the Mobile Ecosystem及其PyTorch实现 MobileNetV4 - Universal Models for the Mobile Ecosystem PDF: https://arxiv.org/pdf/2404.10518.pdf PyTorch代码: https://github.com/shanglianlm0525/CvPytorch PyTorch代码: ht…