【蓝桥杯冲刺】蓝桥杯12届省赛C++b组真题-编程题

简介: 【蓝桥杯冲刺】蓝桥杯12届省赛C++b组真题-编程题

试题F:时间显示

【问题描述】


小蓝要和朋友合作开发一个时间显示的网站。


在服务器上,朋友已经获取了当前的时间,用一个整数表示,


值为从 1970 年 1 月 1 日 00 : 00 : 00 到当前时刻经过的毫秒数。


现在,小蓝要在客户端显示出这个时间。


小蓝不用显示出年月日,只需显示出时分秒即可,毫秒也不用显示,直接舍去即可。


给定一个用整数表示的时间,请将这个时间对应的时分秒输出。


【输入格式】


输入一行包含一个整数,表示时间。


【输出格式】


输出时分秒表示的当前时间,格式形如 H H:M M:S S ,


其中 H H 表示时,值为 0 到 23,


M M 表示分,值为 0  到 59,


S S 表示秒,值为 0 到 59 。


时、分、秒不足两位时补前导 0 。


【测试样例1】


Input:
46800999
Output:
13:00:00

【测试样例2】



Input:1618708103123Output:01:08:23

Input:
1618708103123
Output:
01:08:23

【评测用例规模与约定】


对于所有评测用例,给定的时间为不超过10的18次方的正整数。


解题思路

这是一道简单的模拟题,


根据题目给的毫秒数,求出当前的时间就行。


代码

#include 
using namespace std;
int main() {
  long long t;
  cin >> t;
  int h = t / 1000 / 60 / 60 % 24;
  int m = t / 1000 / 60 % 60;
  int s = t / 1000 % 60;
  printf("%02d:%02d:%02d", h, m, s);
  return 0;
}

试题G:砝码称重

【问题描述】


你有一架天平和 N 个砝码,


这 N 个砝码重量依次是 W1 , W2 , ⋅ ⋅ ⋅ , WN 。


请你计算一共可以称出多少种不同的重量?


注意砝码可以放在天平两边。


【输入格式】


你有一架天平和 N 个砝码,这 N 个砝码重量依次是 W1 , W2 , ⋅ ⋅ ⋅ , WN 。


【输出格式】


输出一个整数代表答案。


【测试样例1】


Input:
3
1 4 6
Output:
10
Explanation:

能称出的 10 种重量是:1、2、3、4、5、6、7、9、10、11。

1 = 1;
2 = 6 − 4 (天平一边放 6,另一边放 4);
3 = 4 − 1;
4 = 4;
5 = 6 − 1;
6 = 6;
7 = 1 + 6;
9 = 4 + 6 − 1;
10 = 4 + 6;
11 = 1 + 4 + 6。


【评测用例规模与约定】


对于 50% 的评测用例,1 ≤ N ≤ 15 。


对于所有评测用例,1 ≤ N ≤ 100 ,N  个砝码总重不超过 100000 。


解题思路

这是一道动态规划题目啊,


但是我不会动态规划,所以我就只能写个暴力搜索,


下面是代码:(只能过50%用例)


代码

#include 
using namespace std;
int n, res;
int w[10000];
bool st[10000];
void dfs(int x, int sum) {
  if (x == n) {
  //有重量且该重量没被标记过
  if (!st[sum] && sum > 0) {
    st[sum] = true;
    res++;
    return;
  }
  }
  else {
  dfs(x + 1, sum + w[x]);//放左边
  dfs(x + 1, sum);    //不放
  dfs(x + 1, sum - w[x]);//放右边
  }
}
int main() {
  scanf("%d", &n);
  for (int i = 0; i < n; i++) scanf("%d", &w[i]);
  dfs(0, 0);
  printf("%d\n", res);
  return 0;
}

试题H:杨辉三角

【问题描述】


下面的图形是著名的杨辉三角形:


如果我们按从上到下、从左到右的顺序把所有数排成一列,可以得到如下数列:



如果我们按从上到下、从左到右的顺序把所有数排成一列,可以得到如下数列:


1, 1, 1, 1, 2, 1, 1, 3, 3, 1, 1, 4, 6, 4, 1, ...


给定一个正整数 N,请你输出数列中第一次出现 N 是在第几个数?


【输入格式】


输入一个整数 N。


【输出格式】


输出一个整数代表答案。


【测试样例1】


Input:
6
Output:
13

【评测用例规模与约定】


对于 20% 的评测用例,1 ≤ N ≤ 10;


对于所有评测用例,1 ≤ N ≤ 1e9 。


解题思路

菜鸟做不出来,


只能暴力枚举1000个数构造杨辉三角。


(只拿40%左右的分数)


代码

#include 
using namespace std;
const int N = 1010;
int n = 1000;
int x;
int a[N][N];
int main() {
  scanf("%d", &x);
  a[1][1] = 1;
  for (int i = 2; i <= n; i++) {
  for (int j = 1; j <= i; j++) {
    a[i][j] = a[i - 1][j - 1] + a[i - 1][j];
  }
  }
  int cnt = 0;
  for (int i = 1; i <= n; i++) {
  for (int j = 1; j <= i; j++) {
    cnt++;
    if (a[i][j] == x) {
    cout << cnt << endl;
    return 0;
    }
  }
  }
  return 0;
}


试题I:双向排序

【问题描述】


给定序列 (a1, a2, ⋅⋅⋅, an) = (1, 2,⋅⋅⋅, n),即 ai = i 。


小蓝将对这个序列进行 m 次操作,


每次可能是将 a1 , a2 , ⋅⋅⋅ , aqi 降序排列,或者将 aqi, aqi + 1 升序排列。


请求出操作完成后的序列。


【输入格式】


输入的第一行包含两个整数 n, m,分别表示序列的长度和操作次数。


接下来 m 行描述对序列的操作,其中第 i 行包含两个整数 pi, qi 表示操作类型和参数。


当 pi = 0 时,表示将 a1, a2,⋅⋅⋅,aqi 降序排列;当 pi = 1时,表示将 aqi, aqi + 1,⋅⋅⋅ , an 升序排列。


【输出格式】


输出一行,包含 n 个整数,相邻的整数之间使用一个空格分隔,表示操作完成后的序列。


【测试样例1】


Input:
3 3
0 3
1 2
0 2
Output:
3 1 2

【评测用例规模与约定】


对于 30%30% 的评测用例,n,m≤1000;


对于 60%60% 的评测用例,n,m≤5000;


对于所有评测用例,1 ≤ n, m ≤ 1e5,0 ≤ pi ≤ 1,1 ≤ qi ≤ n1 。


解题思路

太难了,我写不出来。。。。


试题J:括号序列

解题思路

别看啦,这题我更做不出来了。。。呜呜。。。




写在最后:

以上就是本篇文章的内容了,感谢你的阅读。


如果喜欢本文的话,欢迎点赞和评论,写下你的见解。


如果想和我一起学习编程,不妨点个关注,我们一起学习,一同成长。


之后我还会输出更多高质量内容,欢迎收看。


相关文章
|
21天前
|
C++
C++ 语言异常处理实战:在编程潮流中坚守稳定,开启代码可靠之旅
【8月更文挑战第22天】C++的异常处理机制是确保程序稳定的关键特性。它允许程序在遇到错误时优雅地响应而非直接崩溃。通过`throw`抛出异常,并用`catch`捕获处理,可使程序控制流跳转至错误处理代码。例如,在进行除法运算或文件读取时,若发生除数为零或文件无法打开等错误,则可通过抛出异常并在调用处捕获来妥善处理这些情况。恰当使用异常处理能显著提升程序的健壮性和维护性。
38 2
|
21天前
|
算法 C语言 C++
C++语言学习指南:从新手到高手,一文带你领略系统编程的巅峰技艺!
【8月更文挑战第22天】C++由Bjarne Stroustrup于1985年创立,凭借卓越性能与灵活性,在系统编程、游戏开发等领域占据重要地位。它继承了C语言的高效性,并引入面向对象编程,使代码更模块化易管理。C++支持基本语法如变量声明与控制结构;通过`iostream`库实现输入输出;利用类与对象实现面向对象编程;提供模板增强代码复用性;具备异常处理机制确保程序健壮性;C++11引入现代化特性简化编程;标准模板库(STL)支持高效编程;多线程支持利用多核优势。虽然学习曲线陡峭,但掌握后可开启高性能编程大门。随着新标准如C++20的发展,C++持续演进,提供更多开发可能性。
41 0
|
3月前
|
编译器 C++ 开发者
C++一分钟之-C++20新特性:模块化编程
【6月更文挑战第27天】C++20引入模块化编程,缓解`#include`带来的编译时间长和头文件管理难题。模块由接口(`.cppm`)和实现(`.cpp`)组成,使用`import`导入。常见问题包括兼容性、设计不当、暴露私有细节和编译器支持。避免这些问题需分阶段迁移、合理设计、明确接口和关注编译器更新。示例展示了模块定义和使用,提升代码组织和维护性。随着编译器支持加强,模块化将成为C++标准的关键特性。
131 3
|
12天前
|
Rust 安全 C++
系统编程的未来之战:Rust能否撼动C++的王座?
【8月更文挑战第31天】Rust与C++:现代系统编程的新选择。C++长期主导系统编程,但内存安全问题频发。Rust以安全性为核心,通过所有权和生命周期概念避免内存泄漏和野指针等问题。Rust在编译时确保内存安全,简化并发编程,其生态系统虽不及C++成熟,但发展迅速,为现代系统编程提供了新选择。未来有望看到更多Rust驱动的系统级应用。
35 1
|
2月前
|
人工智能 JavaScript 开发工具
C++中的AI编程助手添加
今天为大家推荐一款适配了 Viusal Studio(本文使用),VS Code(本文使用),JetBrains系列以及Vim等多种编译器环境的插件 Fitten Code,Fitten Code 是由非十大模型驱动的 AI 编程助手,它可以自动生成代码,提升开发效率,帮您调试 Bug,节省您的时间,另外还可以对话聊天,解决您编程碰到的问题。 Fitten Code免费且支持 80 多种语言:Python、C++、Javascript、Typescript、Java等。
74 8
|
21天前
|
存储 编译器 C++
打破C++的神秘面纱:一步步带你走进面向未来的编程世界!
【8月更文挑战第22天】C++是一门功能强大但学习曲线陡峭的语言,提供高性能与底层控制。本文通过实例介绍C++基础语法,包括程序结构、数据类型、控制结构和函数。从简单的“Hello, C++!”程序开始,逐步探索变量声明、数据类型、循环与条件判断,以及函数定义与调用。这些核心概念为理解和编写C++程序打下坚实基础,引导你进入C++编程的世界。
31 0
|
3月前
|
存储 自然语言处理 C++
【C++航海王:追寻罗杰的编程之路】set|map|multiset|multimap简单介绍
【C++航海王:追寻罗杰的编程之路】set|map|multiset|multimap简单介绍
33 0
【C++航海王:追寻罗杰的编程之路】set|map|multiset|multimap简单介绍
|
29天前
|
C++ 容器
C++中自定义结构体或类作为关联容器的键
C++中自定义结构体或类作为关联容器的键
30 0
|
8天前
|
存储 编译器 C++
C ++初阶:类和对象(中)
C ++初阶:类和对象(中)
|
8天前
|
C++
C++(十六)类之间转化
在C++中,类之间的转换可以通过转换构造函数和操作符函数实现。转换构造函数是一种单参数构造函数,用于将其他类型转换为本类类型。为了防止不必要的隐式转换,可以使用`explicit`关键字来禁止这种自动转换。此外,还可以通过定义`operator`函数来进行类型转换,该函数无参数且无返回值。下面展示了如何使用这两种方式实现自定义类型的相互转换,并通过示例代码说明了`explicit`关键字的作用。