在一个古老的部落里,有一个关于天气之子的试炼。 试炼将会给出连续 n n 天的天气情况。每种天气被一个正整数编号。相同的正整数表示同一种天气。 每一天前,接受天气之子试炼的成员们必须每天给出当天的天气预报。预报准确率最高的会成为部落的天气之子。 你想出了一个奇妙的预报方法: 第一天预报天气为 <天气类型1>。从第二天开始: 若前一天预报成功,预报的天气类型保持不变。 若预报失败,统计前面所有天中的最多的天气(多种天气都是最多时,预报其中该天气第一次出现最晚的天气种类),修改当天的预报为该天气。 你的任务是计算你的预报成功天数。 输入格式 第一行一个正整数 n n,表示一共有 n n 天进行天气预报。 接下来一行 n n 个正整数 a 1 . . . a n a 1 ...a n ,其中 a i a i 表示第 i i 天的天气情况。相同的正整数表示相同的天气。 输出格式 一行一个正整数,表示预报成功的天数。 使用c++语言
```cpp #include <iostream> #include <vector> #include <unordered_map> using namespace std; int main() { int n; cin >> n; vector<int> weather(n); for (int i = 0; i < n; i++) { cin >> weather[i]; } // 第一天预报为天气1 int forecast = weather[0]; int correct = 0; // 记录每种天气的出现次数 unordered_map<int, int> count; // 记录每种天气第一次出现的最后位置 unordered_map<int, int> lastFirstOccurrence; for (int i = 0; i < n; i++) { // 检查预报是否正确 if (forecast == weather[i]) { correct++; } // 更新当前天气的计数 count[weather[i]]++; // 如果是第一次出现,记录位置 if (lastFirstOccurrence.find(weather[i]) == lastFirstOccurrence.end()) { lastFirstOccurrence[weather[i]] = i; } // 准备下一天的预报(如果是最后一天则不需要) if (i < n - 1) { if (forecast != weather[i]) { // 预报失败,需要修改预报 int maxCount = 0; int bestWeather = -1; int latestFirstOccurrence = -1; // 找出出现次数最多的天气 for (auto& entry : count) { int w = entry.first; int c = entry.second; int firstOccur = lastFirstOccurrence[w]; if (c > maxCount) { maxCount = c; bestWeather = w; latestFirstOccurrence = firstOccur; } else if (c == maxCount) { // 出现次数相同,选择第一次出现最晚的 if (firstOccur > latestFirstOccurrence) { bestWeather = w; latestFirstOccurrence = firstOccur; } } } forecast = bestWeather; } // 如果预报成功,forecast保持不变 } } cout << correct << endl; return 0; } ``` 代码说明: 1. 初始化第一天的预报为实际天气1 2. 遍历每一天: - 检查预报是否正确,统计正确天数 - 更新天气计数和首次出现位置 - 如果不是最后一天且预报失败,重新计算预报: * 找出出现次数最多的天气 * 次数相同时选择第一次出现最晚的天气 3. 输出正确预报的天数 时间复杂度:O(n²)(最坏情况每次都需要遍历count map) 空间复杂度:O(n) [2026-01-19 19:17:32 | AI问答 | 591点数解答]
- [字节豆包] 题目(description): 卫星导航系统(如我国自主研发的北斗卫星导航系统)能实时获取位置、速度、时间等时空信息,在交通运输、农林渔业、气象测报、通信授时、救灾减灾、公共安全等领域都得到了广泛应用。 在应用层面,卫星导航系统一般以报文方式进行数据传输,其中$gprmc是常用报文之一,基本的格式如下: $gprmc,<1>,<2>,<3>,<4>,<5>,<6>,<7>,<8>,<9>,<10>,<11>,<12>*hh <1> utc时间,hhmmss.sss(时分秒.毫秒)格式 <2> 定位状态,a=有效定位,v=无效定位 <3> 纬度ddmm.mmmm(度分)格式 <4> 纬度半球n(北半球)或s(南半球) <5> 经度dddmm.mmmm(度分)格式 <6> 经度半球e(东经)或w(西经) <7> 地面速率(000.0~999.9节) <8> 地面航向(000.0~359.9度,以正北为参考基准) <9> utc日期,ddmmyy(日月年)格式 <10> 磁偏角(000.0~180.0度,前面的0也(385点数解答 | 2025-01-08 03:43:54)432
- [字节豆包] 题目(description): 卫星导航系统(如我国自主研发的北斗卫星导航系统)能实时获取位置、速度、时间等时空信息,在交通运输、农林渔业、气象测报、通信授时、救灾减灾、公共安全等领域都得到了广泛应用。 在应用层面,卫星导航系统一般以报文方式进行数据传输,其中$gprmc是常用报文之一,基本的格式如下: $gprmc,<1>,<2>,<3>,<4>,<5>,<6>,<7>,<8>,<9>,<10>,<11>,<12>*hh <1> utc时间,hhmmss.sss(时分秒.毫秒)格式 <2> 定位状态,a=有效定位,v=无效定位 <3> 纬度ddmm.mmmm(度分)格式 <4> 纬度半球n(北半球)或s(南半球) <5> 经度dddmm.mmmm(度分)格式 <6> 经度半球e(东经)或w(西经) <7> 地面速率(000.0~999.9节) <8> 地面航向(000.0~359.9度,以正北为参考基准) <9> utc日期,ddmmyy(日月年)格式 <10> 磁偏角(000.0~180.0度,前面的0也(346点数解答 | 2025-01-08 03:46:29)427
- [字节豆包] 请使用python编程为data={'莱科宁': '236 - 编号:51', '汉密尔顿': '358 - 编号:55', '维泰尔': '294 - 编号:34', '维斯塔潘': '216 - 编号:10', '博塔斯': '227 - 编号:46'}对积分进行排名(182点数解答 | 2024-10-20 16:16:44)255
- [字节豆包] (1)设计pci抽象类,接口内有约定设备启动的start()方法、约定设备关闭的stop()方法 (2)设计描述显卡的displaycard类、描述声卡的soundcard类和描述网卡的netcard类,这三个都是pci的子类,因此具有了pci接口中声明的设备启动start方法和设备关闭stop方法 (3)设计描述主板的mainboard类,该类中有一个pci类型的数组,描述主板提供的5个插槽,有一个add(pci device)方法,实现向主板插入指定pci设备device,有一个run()方法,实现依次启动主板上的所有pci设备,有一个stop()方法,实现依次关闭主板上所有pci设备 (4)设计计算机类computer类,该类有一个私有的mainboard类型的成员变量cmb, 有一个start()方法,实现开机、运行主板设备的功能;有一个stop()方法,实现关机,停止主板设备的功能 (5)设计computertest主类,在main方法中,创建computer类型的对象com,并通过方法调用模拟启动计算机,关闭计算机操作。(716点数解答 | 2024-12-08 23:38:38)296
- [字节豆包] 模拟实现如下情形:计算机包括主板,主板上有5个pci插槽,可插装显卡、声卡、网卡等pci设备。主板启动时,依次启动主板上的各个pci设备,关机时,依次关闭主板上的各个pci设备。 (1)设计pci抽象类,接口内有约定设备启动的start()方法、约定设备关闭的stop()方法 (2)设计描述显卡的displaycard类、描述声卡的soundcard类和描述网卡的netcard类,这三个都是pci的子类,因此具有了pci接口中声明的设备启动start方法和设备关闭stop方法 (3)设计描述主板的mainboard类,该类中有一个pci类型的数组,描述主板提供的5个插槽,有一个add(pci device)方法,实现向主板插入指定pci设备device,有一个run()方法,实现依次启动主板上的所有pci设备,有一个stop()方法,实现依次关闭主板上所有pci设备 (4)设计计算机类computer类,该类有一个私有的mainboard类型的成员变量cmb, 有一个start()方法,实现开机、运行主板设备的功能;有一个stop()方法,实现关机,停止主板设备的功能 (5)设计co(637点数解答 | 2024-12-09 08:31:54)269
- [字节豆包] #include <iostream> #include <cstdlib> #include <queue> using namespace std; int findTheWinner(int n, int k) { //在此处写入代码 //返回获胜者序号 } 本关任务: 共有 n 名小伙伴一起做游戏。小伙伴们围成一圈,按 顺时针顺序 从 1 到 n 编号。确切地说,从第 i 名小伙伴顺时针移动一位会到达第 (i+1) 名小伙伴的位置,其中 1 <= i < n ,从第 n 名小伙伴顺时针移动一位会回到第 1 名小伙伴的位置。 游戏遵循如下规则: 从第 1 名小伙伴所在位置 开始 。 沿着顺时针方向数 k 名小伙伴,计数时需要 包含 起始时的那位小伙伴。逐个绕圈进行计数,一些小伙伴可能会被数过不止一次。 你数到的最后一名小伙伴需要离开圈子,并视作输掉游戏。 如果圈子中仍然有不止一名小伙伴,从刚刚输掉的小伙伴的 顺时针下一位 小伙伴 开始,回到步骤 2 继续执行。 否则,圈子中最后一名小伙伴赢得游戏。 给你参与游戏的小伙伴总数 n ,和一个整数 k ,返(235点数解答 | 2025-11-05 15:04:55)82
- [字节豆包] 我要使用 MySQL 数据库,操作一个名为 student 的表,该表包含 id(int 类型)、name(varchar 类型)、age(int 类型)字段。使用 德鲁伊 连接池和 Spring JDBC 进行数据库操作,从 .properties 文件中读取连接池所需的参数。对 student 表按 id 进行查询操作,将查询结果用 Student 类封装,该类包含 id、name、age 属性。代码采用 MVC 架构,将数据持久层代码放在 dao 包下的 StudentDao 类中,同时提供测试上述功能的代码,测试功能使用junit4.0以上技术实现,使用@Transactional注解标记service类,将若干个增删改操作打包成一个事务,并验证事务的有效性,并写出它的pom.xml文件(1115点数解答 | 2025-03-19 11:17:31)264
- [DeepSeek] 我要使用 MySQL 数据库,操作一个名为 student 的表,该表包含 id(int 类型)、name(varchar 类型)、age(int 类型)字段。使用 德鲁伊 连接池和 Spring JDBC 进行数据库操作,从 .properties 文件中读取连接池所需的参数。对 student 表按 id 进行查询操作,将查询结果用 Student 类封装,该类包含 id、name、age 属性。代码采用 MVC 架构,将数据持久层代码放在 dao 包下的 StudentDao 类中,同时提供测试上述功能的代码,测试功能使用junit4.0以上技术实现,使用@Transactional注解标记service类,将若干个增删改操作打包成一个事务,并验证事务的有效性,并写出它的pom.xml文件(1275点数解答 | 2025-03-19 11:21:32)250
- [字节豆包] 子序列:是指在序列中选择某些元素,按照序列中的顺序连接在一起形成的。比如 blm、bl、oea、ma 都是 bolema 的子序列。但 loe 这个序列不是。我们定义子序列长度为子序列中包含的元素数量,比如 blm 的长度为 3,bl 的长度为 2。如果没有特殊说明,空序列和整个序列都是原序列的一个子序列。我们一般会用非空子序列来排除空序列,用真子序列来排除整个序列,用非空真子序列来同时排除两个。 子串:是指在序列中选择连续的某些元素,按照序列中的顺序连接在一起形成的,所以子串也常被称作连续子序列。比如 bol、lem 都是 bolema 的子串。但 blm 不是。与子序列相同,子串包含的元素个数也被称为子串的长度,同时也有“非空”、“真”等描述方法。 现在小a得到了一个仅包含英文小写字母的字符串 s,小a想要在其中找到一个子串 t,使得 bolema 是 t 的子序列。显然有可能有多个这样的 t,小a想要一个知道最短的 t 的长度是多少。 比如当 s 为 bboboxleymabobo 时,子串 boboxleyma、boxleymabobo、boxleyma 等都包含子序列(188点数解答 | 2024-11-15 20:51:47)295
- [GPT] 子序列:是指在序列中选择某些元素,按照序列中的顺序连接在一起形成的。比如 blm、bl、oea、ma 都是 bolema 的子序列。但 loe 这个序列不是。我们定义子序列长度为子序列中包含的元素数量,比如 blm 的长度为 3,bl 的长度为 2。如果没有特殊说明,空序列和整个序列都是原序列的一个子序列。我们一般会用非空子序列来排除空序列,用真子序列来排除整个序列,用非空真子序列来同时排除两个。 子串:是指在序列中选择连续的某些元素,按照序列中的顺序连接在一起形成的,所以子串也常被称作连续子序列。比如 bol、lem 都是 bolema 的子串。但 blm 不是。与子序列相同,子串包含的元素个数也被称为子串的长度,同时也有“非空”、“真”等描述方法。 现在小a得到了一个仅包含英文小写字母的字符串 s,小a想要在其中找到一个子串 t,使得 bolema 是 t 的子序列。显然有可能有多个这样的 t,小a想要一个知道最短的 t 的长度是多少。 比如当 s 为 bboboxleymabobo 时,子串 boboxleyma、boxleymabobo、boxleyma 等都包含子序列(161点数解答 | 2024-11-15 20:52:38)251
- [字节豆包] 输入一个正整数 N,输出 N 行 N 列字母,字母为大写英文字母,执行效果如下。输入正整数 27,输出 27 行字母,每行 27 个字母。第一行从A 开始,第二行 B 开始。当到达 Z,再从 A 开始。c++ image 输入格式 输入一行,一个大于等于 1 的正整数 N。 输出格式 输出上图所示的字母阵列。(340点数解答 | 2026-01-02 19:26:59)27
- [字节豆包] 小 L 和小 Q 在玩一个策略游戏。 有一个长度为 的数组 和一个长度为 的数组 ,在此基础上定义一个大小为 的矩阵 ,满足 。所有下标均从 开始。 游戏一共会进行 轮,在每一轮游戏中,会事先给出 个参数 ,满足 、 。 游戏中,小 L 先选择一个 之间的下标 ,然后小 Q 选择一个 之间的下标 。定义这一轮游戏中二人的得分是 。 小 L 的目标是使得这个得分尽可能大,小 Q 的目标是使得这个得分尽可能小。同时两人都是足够聪明的玩家,每次都会采用最优的策略。 请问:按照二人的最优策略,每轮游戏的得分分别是多少? 【数据范围】 对于所有数据, , 。对于每轮游戏而言, , 。 输入 第一行输入三个正整数 ,分别表示数组 ,数组 的长度和游戏轮数。 第二行: 个整数,表示 ,分别表示数组 的元素。 第三行: 个整数,表示 ,分别表示数组 的元素。 接下来 行,每行四个正整数,表示这一次游戏的 。 输出 输出共 行,每行一个整数,分别表示每一轮游戏中,小 L 和小 Q 在最优策略(676点数解答 | 2025-12-12 18:49:42)49