AtCoder Beginner Contest 342 A - D

A - Yay!

大意

给定字符串S,其中有且仅有一个字符与其他不同,输出这个字符的下标(从1开始)。

思路

桶排序统计次数即可。

代码

#include<iostream>
#include<vector>
using namespace std;
int main(){string s;cin >> s;vector<int> a(26, 0);for(int i = 0; i < s.size(); i++) a[s[i] - 'a']++;for(int i = 0; i < s.size(); i++){if(a[s[i] - 'a'] == 1){cout << i + 1 << endl;break;}}return 0;
}

B - Which is ahead?

大意

有 n个人排成一列,从前往后第i个位置的人是编号为P_i的人。下标从1开始

请处理q个查询,每个查询如下:

  • 给定两个整数ab。在编号为a的人和编号为b的人中,输出站在更前面的那个人的编号。

思路

记录一下每个人的下标,然后对于每个询问比较下标大小即可。

代码

#include<iostream>
#include<vector>
using namespace std;
int main(){ios::sync_with_stdio(0);int n, q;cin >> n;vector<int> a(n);for(int i = 0; i < n; i++){cin >> q;a[q - 1] = i;}cin >> q;while(q--){int x, y;cin >> x >> y;if(a[x - 1] < a[y - 1]) cout << x << endl;else cout << y << endl;}return 0;
}

C - Many Replacement

大意

给定一个长度为n的字符串,进行m次操作。

每次操作, 将所有的字符a替换成字符b

输出最后的字符串。

思路

朴素做法的复杂度是O(nm),会超时

我们可以建立一个映射表,每次只需要修改映射表,最后才进行替换。

代码

#include<iostream>
using namespace std;
int main(){ios::sync_with_stdio(0);int n, q;string s;cin >> n >> s;cin >> q;string from, to;from = to = "abcdefghijklmnopqrstuvwxyz";while(q--){char c, d;cin >> c >> d;for(int i = 0; i < 26; i++)if(to[i] == c) to[i] = d;}for(int i = 0; i < n; i++){for(int j = 0; j < 26; j++)if(s[i] == from[j]) cout<<to[j];}return 0;
}

D - Square Pair

大意

一个长度为N的自然数序列A。求满足以下两个条件的整数对(i,j)的个数:

  • 1\le i,j \le n

  • A_i\times A_j是一个完全平方数。(0也是完全平方数)

思路

考虑两个自然数a,b,如果a\times b完全平方数,只有两种情况:

  • a=0b = 0,此时a\times b = 0
  • a\times b是完全平方数且不为0

并且易得x^2\times y^2=(x\times y)^2

所以一个完全平方数因子对 a\times b 是不是完全平方数没有影响。我们可以把ab分别除掉所有完全平方数因子,得到a'b'。由于它们没有完全平方数因子(除了1),所以只有a'=b'时,a'\times b'才是完全平方数

因此,我们把所有A_i除去所有完全平方数因子,然后遍历A_i

每个A_i只有两种情况:

  • A_i\ne 0,那么它与前面和A_i相同的数以及0可以组成一个平方数对。
  • A_i=0,那么它与前面所有数都可以组成一个平方数对。

开个map,一边统计次数,一边计算答案即可。

代码

#include<iostream>
#include<vector>
#include<unordered_map>using namespace std;
#define int long longsigned main(){ios::sync_with_stdio(0);cin.tie(0), cout.tie(0);int n;cin >> n;vector<int> a(n + 1, 0);auto divide = [&](int x){for(int i = 2; i <= x / i; i++)while(x % (i * i) == 0) x /= (i * i);return x;};for(int i = 1; i <= n; i++){cin >> a[i];a[i] = divide(a[i]);}int ans = 0;unordered_map<int, int> times;for(int i = 1; i <= n; i++){if(a[i]) ans += times[a[i]] + times[0];else ans += i - 1;times[a[i]]++;}cout << ans << endl;return 0;
}

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

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

相关文章

【前端面试3+1】06继承方式及优缺点、缓存策略、url输入到渲染全过程、【二叉树中序遍历】

一、继承有哪些方式&#xff1f;以及优缺点 继承的方式包括原型链继承、构造函数继承、组合继承、原型式继承、寄生式继承和组合式继承。 1.原型链继承&#xff1a; 实现方式&#xff1a;将子类的原型指向父类的实例来实现继承。优点&#xff1a;简单易懂&#xff0c;代码量少。…

如何制作伸缩侧边栏?

目录 一、html-body 二、CSS 三、JS 四、完整代码 五、效果展示 一、html-body 侧边栏的伸缩需要用户触发事件&#xff0c;这里使用button为例&#xff0c;用户点击按钮实现侧边栏的打开和关闭。 <body><!-- 按钮&#xff0c;可以用文字、图片等作为事件源&am…

十三.youyiku分析案例(数分)

目录 youyiku分析案例(数分) 大框操作 1.销售情况随着时间的变化 2.不同产品的销量 柱状图(bar)改颜色排序 seaborn库(柱) --排序 3.每个城市的人喜欢的购物方式 4-不同年龄段的购物方式 添加标签段及值 --创建新表 对标签分别计算 绘图分析 youyiku分析案例(数分…

session反序列化漏洞2——ctfshow web263

题目链接 https://ctf.show/challenges#web263-723 解题思路 进去先是一个登录框 目录扫描一下发现存在源码泄露 查看源码 index.php error_reporting(0);session_start();//超过5次禁止登陆if(isset($_SESSION[limit])){$_SESSION[limti]>5?die("登陆失败次数超…

智过网:中级安全工程师一年能挣多少钱?工资高吗?

中级安全工程师的年收入是广大从业者非常关心的问题。毕竟&#xff0c;了解自己所处行业的薪资水平&#xff0c;不仅有助于规划个人职业发展&#xff0c;还能为日常生活中的决策提供重要参考。那么&#xff0c;中级安全工程师一年究竟能挣多少钱呢&#xff1f;工资又是否算高呢…

[leetcode] 100. 相同的树

给你两棵二叉树的根节点 p 和 q &#xff0c;编写一个函数来检验这两棵树是否相同。 如果两个树在结构上相同&#xff0c;并且节点具有相同的值&#xff0c;则认为它们是相同的。 示例 1&#xff1a; 输入&#xff1a;p [1,2,3], q [1,2,3] 输出&#xff1a;true示例 2&a…

YOLOV5训练自己的数据集教程(万字整理,实现0-1)

文章目录 一、YOLOV5下载地址 二、版本及配置说明 三、初步测试 四、制作自己的数据集及转txt格式 1、数据集要求 2、下载labelme 3、安装依赖库 4、labelme操作 五、.json转txt、.xml转txt 六、修改配置文件 1、coco128.yaml->ddjc_parameter.yaml 2、yolov5x.…

第1章.提示词:开启AI智慧之门的钥匙

什么是提示词&#xff1f; 提示词&#xff0c;是引导语言模型的指令&#xff0c;让用户能够驾驭模型的输出&#xff0c;确保生成的文本符合需求。 ChatGPT&#xff0c;这位文字界的艺术大师&#xff0c;以transformer架构为基石&#xff0c;能轻松驾驭海量数据&#xff0c;编织…

嵌入式第一部分-第一集:ARM那些你得知道的事

ARM&#xff1a;Advanced RISC Machine&#xff0c;先进精简指令集机器 ARM公司只做设计&#xff0c;不生产。 国内IC生产厂商&#xff1a;华为海思、全志、瑞芯微、MTK&#xff08;联发科&#xff09; 扩展&#xff1a;ARM的商业模式了解。 使用三星S5PV210开发板进行视频的讲…

大数据 - Hadoop系列《五》- HDFS文件块大小及小文件问题

系列文章&#xff1a; 大数据- Hadoop入门-CSDN博客 大数据 - Hadoop系列《二》- Hadoop组成-CSDN博客 大数据 - Hadoop系列《三》- HDFS&#xff08;分布式文件系统&#xff09;概述_大量小文件的存储使用什么分布式文件系统-CSDN博客 大数据 - Hadoop系列《三》- MapRedu…

LeetCode算法——数组/字符串篇

对刷过的算法进行总结&#xff0c;所用解法都是最符合我个人逻辑的&#xff0c;以后再刷的话就看这篇帖子了 # 代码随想录——数组理论基础 首先要知道数组在内存中的存储方式&#xff0c;这样才能真正理解数组相关的面试题 数组是存放在连续内存空间上的相同类型数据的集合 …

IntelliJ IDEA 2023 for Mac 好用的Java开发工具

IntelliJ IDEA 2023是一款由JetBrains开发的强大的集成开发环境&#xff08;IDE&#xff09;软件&#xff0c;适用于多个编程语言。它旨在提高开发人员的生产力和代码质量&#xff0c;具有以下多种特色功能&#xff1a; 软件下载&#xff1a;IntelliJ IDEA 2023 v2023.3.6中文激…

2d导入人物素材进行分割后设置图层

1、设置分辨率大小 2、相机调整大小&#xff0c;要符合场景 3、选择2D sprite 编辑器 或者 点击这个也行 4、分割图像 5、设置过滤模式 6、图层设置

CAJViewer8.1下载地址及安装教程

CAJViewer是中国学术期刊&#xff08;CAJ&#xff09;全文数据库的专用阅读软件。CAJViewer是中国知识资源总库&#xff08;CNKI&#xff09;开发的一款软件&#xff0c;旨在方便用户在线阅读和下载CAJ数据库中的学术论文、期刊和会议论文等文献资源。 CAJViewer具有直观的界面…

Modbus协议介绍

Modbus存储区 从机存储数据&#xff0c;那么肯定要有一个存储区&#xff0c;那就需要文件操作&#xff0c;我们都知道这文件可以分为只读(-r)和读写(-wr)两种类型 并且存储的数据类型可以分为 &#xff1a;布尔量 和 16位寄存器 布尔量比如IO口的电平高低&#xff0c;灯的开关…

金仓方案 | 全国高速联网收费系统国产化升级进行时

近年来&#xff0c;国家提出了交通强国建设战略&#xff0c;鼓励在交通领域加强自主创新&#xff0c;推动产业转型升级。高速公路收费系统作为高速公路行业的核心&#xff0c;也是交通领域信息技术应用创新的重中之重&#xff0c;自主可控问题成为系统建设和运营的关键难点。 2…

[机器学习]练习闵可斯基距离

闵可斯基距离&#xff08;Minkowski distance&#xff09;是一种用于衡量向量空间中两点之间距离的方法。它是曼哈顿距离和欧几里得距离的一般化形式。闵可斯基距离使用一个参数 p 来调整计算方法&#xff0c;其中 p 是一个大于 0 的实数值。 在二维空间中&#xff0c;闵可斯基…

可控占比闪烁电路

1启动Q0.0 亮一秒歇一秒循环执行 定时器设置为2秒 使用指令LD> T0 k10 控制亮和灭时间

mysql 用户管理-权限管理

学习了用户管理&#xff0c;再学习下权限管理。 3&#xff0c;权限管理 权限管理主要是对登录到MySQL的用户进行权限验证。所有用户的权限都存储在MySQL的权限表中&#xff0c;不合理的权限规划会给MySQL服务器带来安全隐患。数据库管理员要对所有用户的权限进行合理规…

腾讯2024实习生在线笔试-0331

Q1 小红的图上染色 小红拿到了一个无向图&#xff0c;其中一些边被染成了红色。 小红定义一个点是“好点”&#xff0c;当且仅当这个点的所有邻边都是红边。 现在请你求出这个无向图“好点”的数量。 注&#xff1a;如果一个节点没有任何邻边&#xff0c;那么它也是好点。 …