当前位置: 首页 > news >正文

C++编程实战:高效解决算法与数据结构问题

个人主页 : zxctscl
专栏 【C++】、 【C语言】、 【Linux】、 【数据结构】、 【算法】
如有转载请先通知

题目

  • 1. 数字统计
  • 2. 两个数组的交集
  • 3. 牛牛的快递
  • 4. 点击消除
  • 5. 最小花费爬楼梯
  • 6. 简写单词

1. 数字统计

BC153 数字统计
在这里插入图片描述

#include <iostream>
using namespace std;int main() {int a, b;cin >> a >> b; int count;for(int i=a;i<=b;i++){int tmp=i;//避免修改原数据while(tmp){if(tmp%10==2)count++;tmp/=10;}}cout<<count;
}
// 64 位输出请用 printf("%lld")

2. 两个数组的交集

NC313 两个数组的交集
在这里插入图片描述

class Solution {
public:/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** * @param nums1 int整型vector * @param nums2 int整型vector * @return int整型vector*/vector<int> intersection(vector<int>& nums1, vector<int>& nums2){unordered_set<int> hash1(nums1.begin(),nums1.end());unordered_set<int> hash2(nums2.begin(),nums2.end());vector<int> ret;for(auto x:hash2){if(hash1.count(x))ret.push_back(x);hash1.insert(x);}return ret;// write code here}
};

3. 牛牛的快递

BC64 牛牛的快递

在这里插入图片描述

#include <iostream>
using namespace std;int main() {double a;char b;int sum=20;cin>>a>>b;if(a<=1){if(b=='y')sum+=5;cout<<sum;}else {double tmp=a-1;if(tmp-(int)tmp==0)sum+=tmp;else{ sum+=tmp/1+1;}if(b=='y')sum+=5;cout<<sum;}}
// 64 位输出请用 printf("%lld")

4. 点击消除

AB5 点击消除

在这里插入图片描述
模拟栈

#include <iostream>
using namespace std;int main() {string s;cin>>s;string ret;for(int i=0;i<s.size();i++){if(ret.size()&&ret.back()==s[i])ret.pop_back();else ret+=s[i];}if(ret.size()==0)cout<<"0";else cout<<ret;}
// 64 位输出请用 printf("%lld")

5. 最小花费爬楼梯

DP4 最小花费爬楼梯
在这里插入图片描述

#include <iostream>
using namespace std;
const int N = 1e5 + 10;
int n;
int cost[N];
int dp[N];
int main() {cin >> n;for (int i = 0; i < n; i++) cin >> cost[i];if(n==1)//边界情况{cout<<cost[0]<<endl;}else{for (int i = 2; i <= n; i++) {dp[i] = min(dp[i - 1] + cost[i - 1], dp[i - 2] + cost[i - 2]);}cout << dp[n] << endl;}return 0;
}
// 64 位输出请用 printf("%lld")

6. 简写单词

在这里插入图片描述
模拟

BC149 简写单词

#include <iostream>
using namespace std;int main() {string s;while(cin>>s)//自动跳空格,仅需处理每一个单词首字母{if(s[0]<='z'&&s[0]>='a')cout<<(char)(s[0]-32);else cout<<s[0];}
}
// 64 位输出请用 printf("%lld")
http://www.lryc.cn/news/624108.html

相关文章:

  • Linux817 shell:until,nfs,random
  • React 第七十节 Router中matchRoutes的使用详解及注意事项
  • Next.js跟React关系(Next.js是基于React库的全栈框架)(文件系统路由、服务端渲染SSR、静态生成SSG、增量静态再生ISR、API路由)
  • Vue 与 React 深度对比:设计哲学、技术差异与应用场景
  • 每日Java面试系列(15):进阶篇(String不可变的原因、性能问题、String三剑客、自定义不可变设计、组合优于继承等相关问题)
  • FreeRTOS源码分析八:timer管理(一)
  • Linux学习-多任务(线程)
  • Python 项目里的数据清理工作(数据清洗步骤应用)
  • RK3588开发板Ubuntu系统烧录
  • 「数据获取」《中国教育统计年鉴》(1949-2023)(获取方式看绑定的资源)
  • Python @staticmethod 装饰器与 staticmethod() 函数
  • Spring AI 集成阿里云百炼平台
  • C语言课程开发
  • C11期作业17(07.05)
  • Effective C++ 条款47: 使用traits classes表现类型信息
  • JVM常用工具:jstat、jmap、jstack
  • Transformer架构的数学本质:从注意力机制到大模型时代的技术内核
  • 因果语义知识图谱如何革新文本预处理
  • 机器学习案例——对好评和差评进行预测
  • Python开发环境
  • 说一下事件传播机制
  • Pandas数据结构详解Series与DataFrame
  • 【C#补全计划】多线程
  • 《解构WebSocket断网重连:指数退避算法的前端工业级实践指南》
  • 代码随想录刷题——字符串篇(五)
  • MySQL数据库初识
  • Linux 服务:iSCSI 存储服务配置全流程指南
  • 「数据获取」《中国文化文物与旅游统计年鉴》(1996-2024)(获取方式看绑定的资源)
  • ICCV 2025 | Reverse Convolution and Its Applications to Image Restoration
  • 一键管理 StarRocks:简化集群的启动、停止与状态查看