StarryCoding 入门教育赛 3 题解C++

比赛链接:https://www.starrycoding.com/contest/8

A. 坐标变换

语法题,考察输入输出、循环结构、数学运算。

#include <bits/stdc++.h>
using namespace std;
using ll = long long;const ll p = 998244353;
const int N = 2e5 + 9;void solve()
{int n;cin >> n;ll x = 0, y = 0;for (int i = 1; i <= n; ++i){ll dx, dy;cin >> dx >> dy;x += dx, y += dy;}cout << x << ' ' << y << '\n';
}int main()
{ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);int _;cin >> _;while (_--)solve();return 0;
}

B. 自助店评分

考察STL中struing, map的使用。

对STL不熟悉的同学可以看下《算法基础课》:https://www.starrycoding.com/course/1

#include <bits/stdc++.h>
using namespace std;
using ll = long long;const ll p = 998244353;
const int N = 2e5 + 9;void solve()
{map<string, ll> mp;int n, m;cin >> n >> m;for (int i = 1; i <= n; ++i){string s;ll x;cin >> s >> x;mp[s] = x;}ll ans = 0;for (int i = 1; i <= m; ++i){string s;cin >> s;ans = max(ans, mp[s]);}cout << ans << '\n';
}int main()
{ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);int _;cin >> _;while (_--)solve();return 0;
}

C.打字糕手

考察题目理解能力,字符串和下标变换灵活运用。

#include <bits/stdc++.h>
using namespace std;void solve()
{string s, t;cin >> s >> t;for(int i = 0, j = 0;i < t.length() && j < s.length(); ++ i){if(t[i] == s[j]){cout << i + 1 << ' ';j ++;}}cout << '\n';
}int main()
{ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);int _;cin >> _;while(_ --)solve();return 0;
}

D.电弧陷阱

类似这种给一个矩阵,然后有些位置不能去、被挡住、有传送门之类的,一般都需要用到 b f s bfs bfs。这种题就类似于走迷宫,需要保证走过的点不要再走,否则会让时间复杂度变高。

显然电弧陷阱会将整个矩阵分成好几部分连通区域,我们只需要在遍历矩阵的时候判断一下当前位置,是否可以作为出发点即可开始 b f s bfs bfs

此时一个连通部分的答案 = . 的数量 + 电弧数量。

. 的数量我们可以通过找到所有不会被电弧困住的地方来计算,而难点在于如何算出 电弧 的数量。

最简单的方法就是使用set维护一个pair<x, y>直接去重,最后加上 set.size() 即可。

容易出错的地方在于,如果选择将 # 周围的点修改为其他字符做标记,那么一定要在 输入完成后进行bfs之前 进行标记。

还需要注意,题目保证了至少一个点为 . ,因此答案至少为 1。

#include "bits/stdc++.h"char mp[1007][1007];int vis[1007][1007], n, m, ans;const int dir[] = {0, 1, 0, -1, 0};bool check_boom(int x, int y) { // 检查 {x, y} 是否有电弧for (int i = 0; i < 4; ++ i) {int nx = x + dir[i], ny = y + dir[i + 1];if (mp[nx][ny] == '#') return false;}return true;
}bool check(int x, int y) {return x >= 1 and x <= n and y >= 1 and y <= m and mp[x][y] != '#' and check_boom(x, y) and vis[x][y] == 0;
}void bfs(int x, int y) {// . and 电弧std::set<std::pair<int, int>> set_a;std::set<std::pair<int, int>> set_b;// now {x, y}std::queue <std::pair<int, int>> q;q.push({x, y});while (!q.empty()) {auto top = q.front(); q.pop();set_a.insert(top);for (int i = 0; i < 4; ++ i) {int nx = top.first + dir[i], ny = top.second + dir[i + 1]; // next_x, next_yif (check(nx, ny)) {q.push({nx, ny});vis[nx][ny] = 1;}}}// 遍历 . 的 set,检查其周围是否有 电弧for (auto &p : set_a) {for (int i = 0; i < 4; ++ i) {int nx = p.first + dir[i], ny = p.second + dir[i + 1];if (mp[nx][ny] == '.' and vis[nx][ny] == 0) set_b.insert({nx, ny});}}   int num = set_a.size() + set_b.size();    ans = std::max(ans, num);
}signed main() {std::cin >> n >> m;for (int i = 1; i <= n; ++ i) {for (int j = 1; j <= m; ++ j) {std::cin >> mp[i][j];}}for (int i = 1; i <= n; ++ i) {for (int j = 1; j <= m; ++ j) {if (vis[i][j] == 0 and mp[i][j] == '.') {ans = std::max(1, ans); // 只要有一个位置为 . ,答案就至少为1if (check_boom(i, j)) bfs(i, j);}}}std::cout << ans;
}

E.夜游江滩

定义 d p [ i ] dp[i] dp[i]表示从 0 0 0走到 i i i的方案数。

初始化 d p [ 0 ] = 1 dp[0] = 1 dp[0]=1

状态转移方程为: d p [ i ] = ∑ j = 0 [ k j ≤ i ] d p [ j ] dp[i] = \sum_{j=0}[k^j \le i]dp[j] dp[i]=j=0[kji]dp[j]

最后输出 d p [ n ] dp[n] dp[n]

每次转移时间复杂度为 O ( l o g ( i ) ) O(log(i)) O(log(i)),于是总复杂度为 O ( n l o g n ) O(nlogn) O(nlogn)

注意特判 k = 1 k = 1 k=1的情况。

#include <bits/stdc++.h>
using namespace std;
using ll = long long;
const int N = 1e5 + 9;
ll dp[N];
const ll p = 1e9 + 7;void solve()
{int n, k;cin >> n >> k;if(k == 1){cout << 1 << '\n';return;}dp[0] = 1;for (int i = 1; i <= n; ++i){dp[i] = 0;}for (int i = 1; i <= n; ++i){for (ll j = 1; j <= i; j *= k){dp[i] = (dp[i] + dp[i - j]) % p;}}cout << dp[n] << "\n";
}int main()
{ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);int _;cin >> _;while (_--)solve();return 0;
}

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

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

相关文章

鸿蒙应用开发之调用C++开发代码库1

由于鸿蒙应用主要基于ArkTS开发,主要使用的语言是ETS,也就是JS脚本方式来开发,这与C++语言开发是不同的语言,这样就不能直接相互调用,因为不同的语言使用不同的数据结构,不同的调用方式,不同的运行环境。要想在ETS语言里调用C++开发的代码,需要进行合适的转换,并且按指…

Java学习【类与对象—封装】

Java学习【类与对象—封装】 封装的概念封装的实现包的概念import 导包导包中*的介绍import static 导入包中的静态方法和字段 static关键字的使用static 修饰成员变量static修饰方法静态成员变量的初始化 代码块静态代码块非静态代码块/实例化代码块/构造代码块加载顺序 封装的…

什么是外呼系统?企业为什么使用ai电销外呼系统

说起ai电销外呼系统&#xff0c;或许有的人并不了解这是什么&#xff0c;但它却常常出现在我们的生活中&#xff0c;今天我们来看看什么是外呼系统&#xff0c;企业为什么使用ai电销外呼系统&#xff1f; 一、什么是外呼系统 外呼系统就是由系统自动拨打电话的&#xff0c;外呼…

单例模式(饿汉+懒汉)

单例模式 文章目录 单例模式定义饿汉式单例**饿汉式单例需要加volatile关键字吗**类加载过程 懒汉式单列 定义 单例模式(Singleton),保证一个类仅有一个实例&#xff0c;并提供一个访问它的全局访问点 饿汉式单例 饿汉式单例是Java中实现单例模式的一种方式&#xff0c;它在类…

HTML常见标签-标题标签

标题标签 标题标签一般用于在页面上定义一些标题性的内容,如新闻标题,文章标题等,有h1到h6六级标题 代码 <body><h1>一级标题</h1><h2>二级标题</h2><h3>三级标题</h3><h4>四级标题</h4><h5>五级标题</h5>…

视频提取gif的手机端操作方法?看看这个就会了

Gif图片是一种非常流行的格式&#xff0c;广泛应用于社交媒体、网络宣传单等。它们能够轻松的吸引大众的注意力&#xff0c;在使用聊天软件的时候我们常常会使用gif动图表情包来调节聊天氛围。Gif动图比普通的图片有趣&#xff0c;也比视频的体积要小。我们想要通过手机来把视频…

从需求到实现:能源软件服务商如何量身定制企业解决方案

能源行业需要数字化转型的原因主要有以下几点&#xff1a;首先&#xff0c;数字化技术可以提高生产效率和安全性&#xff0c;通过实时监控和智能调度降低事故风险&#xff0c;并实现远程控制和自动化生产。其次&#xff0c;数字化转型有助于推动能源行业的创新发展&#xff0c;…

GPT-4o正式发布;零一万物发布千亿参数模型;英国推出AI评估平台

OpenAI 正式发布 GPT-4o 今天凌晨&#xff0c;OpenAI 正式发布 GPT-4o&#xff0c;其中的「o」代表「omni」&#xff08;即全面、全能的意思&#xff09;&#xff0c;这个模型同时具备文本、图片、视频和语音方面的能力&#xff0c;甚至就是 GPT-5 的一个未完成版。 并且&…

本地安装nvm,管理多版本node

先卸载本地的nodejs(14.16.1) 卸载的直接可以点击win10图标→设置→应用→应用和功能 卸载nodejs即可 2. 安装nvm&#xff0c;地址&#xff1a;https://github.com/coreybutler/nvm-windows/releases 安装目录时尽量不要出现特殊字符还有空格&#xff0c;否则会在nvm use xxx的…

HTML常用标签-列表标签

列表标签 有序列表 分条列项展示数据的标签, 其每一项前面的符号带有顺序特征 无序列表 分条列项展示数据的标签, 其每一项前面的符号不带有顺序特征 有序列表标签 ol无序列表标签 ul列表项标签 li代码 <!-- 有序列表 --><ol><li>JAVA</li><li>前…

python的文件处理

文件分为文本文件和二进制文件&#xff1a; 我这样理解&#xff1a;就是电脑上用记事本打开我们可以看懂的文件就是文本文件&#xff0c;比如docx&#xff0c;txt&#xff0c;cpp&#xff0c;json&#xff0c;md等。直接点开看不懂的就是二进制文件&#xff0c;比如png&#xf…

考研数学|强化《660》+《880》这样刷,太丝滑了❗️

660题880题需要大概两个月才能做完 660题和880题都是很高质量的题集&#xff0c;所以做起来一点也不轻松。 每年都会有学生暑假两个月只做了一本660题的情况&#xff0c;因为题目实在是太难&#xff0c;有点做不下去的感觉。 不过不要担心&#xff0c;暑假就是刷题发现问题的…

k8s 网络组件详细 介绍

目录 一 k8s 有哪些网络组件 二 k8s 网络概念 1&#xff0c; k8s 三种网络 2&#xff0c;K8S 中 Pod 网络通信 2.1 Pod 内容器与容器之间的通信 2.2 同一个 Node 内 Pod 之间的通信 2.3 不同 Node 上 Pod 之间的通信 三 Flannel 网络组件 1&#xff0c;Flannel …

C++干货--引用

前言&#xff1a; C的引用&#xff0c;是学习C的重点之一&#xff0c;它与指针的作用有重叠的部分&#xff0c;但是它绝不是完全取代指针(后面我们也会简单的分析)。 引用的概念&#xff1a; 引用 不是新定义一个变量 &#xff0c;而 是给已存在变量取了一个别名 &#xf…

spring boot 线程池的应用

文章目录 引言I 配置线程池II 封装线程池任务执行器2.1 唯一性标识2.2 LogFilter:设置request_id2.3 logback使用request_idIII 检测线程池引言 SpringBootApplication启动类上需要加入注解@EnableAsync或者在配置类上使用 应用场景:封装线程池任务执行器:在任务提交时,会…

学习uni-app期间css样式的导入、单位属性和ui工具关系

css单位属性 css中单位有&#xff1a; px &#xff1a;屏幕像素 vw&#xff1a;屏幕宽度 vh &#xff1a;屏幕高度 rpx &#xff1a;响应式 px&#xff0c;一种根据屏幕宽度自适应的动态单位。以 750 宽的屏幕为基准&#xff0c;750rpx 恰好为屏幕宽度。屏幕变宽&#xff0c;rp…

【转载】【亲测可用】Ubuntu18.04安装VTK-8.2.0

这篇文章转载大部分都参考自下面的链接&#xff0c;注意cmake的版本&#xff0c;如果版本不对是编译失败的 https://blog.csdn.net/qq_42257666/article/details/124574029?ops_request_misc%257B%2522request%255Fid%2522%253A%2522171566768016800182751339%2522%252C%2522…

Power query与Excel的区别,优势?

Power Query是Microsoft Excel的一个强大数据导入、转换和自动化的插件工具&#xff0c;它在Excel 2010之后的版本中被发布出来&#xff0c;随着时间的发展&#xff0c;功能不断增强。 以下是Power Query的一些优势以及它与Excel传统数据处理方式的区别和一些令人印象深刻的功…

HTML(基础语法)(1)

标题标签 h1~h6双标签 h1一个网页只能用一次 其他可多次使用 段落标签 p 换行<br> 水平线<hr> 文本格式化标签 加粗 strong /b 倾斜 em/i 下划线 ins/u 删除线 del/s 图片标签 <img src"图片"> src用于指定图片的位置和名称 ./开头&…

【选型推荐】洁净室( 区) 悬浮粒子的测试方法及仪器选型

环境监测承担着环境污染控制措施有效性的评判者的角色。其本身不是一个控制措施&#xff0c;环境监测本身并不能够改变环境指标&#xff0c;降低污染。一个有效的环境监测体系是能反映洁净区内的粒子和微生物的真实水平。确认环境是否满足法规的要求&#xff0c;同时给予污染控…