当前位置: 首页 > 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.dtcms.com/a/335643.html

相关文章:

  • 【CV 目标检测】Fast RCNN模型②——算法流程
  • 【递归、搜索与回溯算法】记忆化搜索
  • 图解希尔排序C语言实现
  • 分治-归并-315.计算右侧小于当前元素的个数-力扣(LeetCode)
  • Java基础 8.17
  • Debug马拉松:崩溃Bug的终极挑战
  • 一起Oracle 19c bug 导致的业务系统超时问题分析
  • JUC常用线程辅助类详解
  • Blender模拟结构光3D Scanner(二)投影仪内参数匹配
  • 积鼎科技CFD VirtualFlow:引领国产多相流仿真技术,赋能工业智造
  • (一)React企业级后台(Axios/localstorage封装/动态侧边栏)
  • 【React 性能】性能优化第一课:搞懂 `React.memo`, `useCallback`, `useMemo`
  • 重学React(六):脱围机制二
  • Spark03-RDD02-常用的Action算子
  • WebSocket DevTools 开发调试工具完全指南 – 实时监控、消息拦截、性能分析一站式解决方案
  • 【Java后端】Spring Boot 集成 MyBatis 全攻略
  • 遥感数字图像处理教程——第二章部分课后习题
  • Java零基础笔记20(Java高级技术:单元测试、反射、注解、动态代理)
  • Oracle Undo Tablespace 使用率暴涨案例分析
  • 前端vue3+后端spring boot导出数据
  • 《香农之息》(终章·镜渊)
  • 从零到一:打包并发布你的第一个MCP AI工具服务
  • Qt | 四种方式实现多线程导出数据功能
  • RAG学习(二)
  • 零墨云A4mini打印机设置电脑通过局域网络进行打印
  • scikit-learn/sklearn学习|多任务套索回归MultiTaskLasso解读
  • 如何利用gemini-cli快速了解一个项目以及学习新的组件?
  • 业务员手机报价软件免费领取——仙盟创梦IDE
  • Kotlin集合概述
  • 【LeetCode】13. 罗马数字转整数