C++寒假打卡2.19

题目列表

#字母转换        难度系数 ⭐ (送分)

        #数位求和        难度系数 ⭐⭐ (几乎也是送分)

                #分糖果      难度系数 ⭐⭐⭐ 

                        #猴子摘桃     难度系数 ⭐⭐⭐ (板字题)

                                #最大值      难度系数 ⭐⭐⭐⭐⭐(有一点难度)


#字母转换T1

 🔴题目大意

就是输入一个大写字符, 输出一个小写字符。

有1000,000,000,000,000·····种做法。

 🔴做法

首先可以这样:

#include <bits/stdc++.h>  
using namespace std;  
int main() {  char a;cin >> a;cout <<(char) tolower(a);return 0;  
}

然后可以这样:

#include <bits/stdc++.h>  
using namespace std;  
int main() {  char a;cin >> a;cout <<(char) (a + 32);return 0;  
}

其次:

#include <bits/stdc++.h>  
using namespace std;  
int main() {  char a;cin >> a;cout <<(char) (a - 'A' + 'a');return 0;  
}

#数位求和  T2

  🔴题目大意

给定数n,m,输出在n和m中有几个三个位(数据范围是100~801),加起来是8.

 🔴做法

做法1(数位分离):

#include <bits/stdc++.h>
using namespace std;
int main(){int n, m;cin >> n >> m;int ans = 0;for(int i = n; i <= m; i++){int ii = i;int ge = ii % 10;ii /= 10;int shi = ii % 10;ii /= 10;int bai = ii % 10;if(ge + shi + bai == 8) ans++;}cout << ans;return 0;
}

做法2(万事皆可字符串):

#include <bits/stdc++.h>
using namespace std;
int main(){int n, m;cin >> n >> m;int ans = 0;for(int i = n; i <= m; i++){string s = to_string(i);if((s[0] - '0') + (s[1] - '0') + (s[2] - '0') == 8) ans++;}cout << ans;return 0;
}

#分糖果T3

 🔴样例解释

样例1:


N等于3时,1~3号小朋友原有糖果数量分别为6,4,2。

1)1号小朋友拿出两块给2号小朋友;

2)2号小朋友拿出两块给3号小朋友;

两次操作后三个小朋友手中的糖果分别为4,4,4。

即按照调整规则最少操作2次可以使3个小朋友手中糖果数量相同

 🔴做法

#include <bits/stdc++.h>
using namespace std;
int a[55];
int main(){int n, ans = 0, sum = 0; cin>>n; for(int i = 1; i <= n; i++){cin>>a[i];sum += a[i];                //计算糖果总量 }int avg = sum / n;                //计算最终平均每人拿到的糖果数量 for(int i = 1; i < n; i++){if(a[i] != avg){            //如果某个小朋友拿到的糖果数量与最终平均不相同 ans++;                    //说明他需要给出糖果或者需要拿到糖果,总之需要1次操作 int d = avg - a[i];        //计算这个小朋友已有的糖果和最终平均值的差距 a[i+1] -= d;            //下一个小朋友需要拿出相差的这部分糖果(可能加,也可能减) a[i] += d;                //当前小朋友得到相差的这部分糖果 (可能加,也可能减)}}cout<<ans;return 0;
}

 

#猴子摘桃 T4

🔴样例

样例2:

M=2,N=3

桃子数量为:

2 3 1

1 4 2

这种情况下,为了摘到最多数量的桃子,猴子摘桃子的顺序应为2,3,4,2,总桃子数为11。

🔴做法

这是板字题吧,和数字金字塔一模一样。

#include<bits/stdc++.h>
using namespace std;
//a[i][j]表示第i行第j列的桃子数量,f[i][j]表示到达第i行第j列可以摘到的最大桃子数量 
int a[22][22], f[22][22] = {};        
int main(){int m, n; cin>>m>>n;for(int i = 1; i <= m; i++)for(int j = 1; j <= n; j++)cin>>a[i][j];for(int i = 1; i <= m; i++){ for(int j = 1; j <= n; j++){//第i行第j列可以摘到的最大桃子数量取决于从上方来(即f[i-1][j])能摘到的最大数和从左边来(即f[i][j-1])能摘到的桃子数//在两种可能得路径中选择最大值,再累加当前树上的桃子数量 f[i][j] = max(f[i-1][j], f[i][j-1]) + a[i][j];    }}cout<<f[m][n];return 0;
}

#最大值T5 

 

🔴样例

样例1:

M=2,字符串为123456,插入2个乘号。插入方式有:

1 × 2 × 3456 = 6912,
1 × 23 × 456 = 10488,
1 × 234 × 56 = 13104,
1 × 2345 × 6 = 14070,
12 × 3 × 456 = 16416,
12 × 34 × 56 = 22848,
12 × 345 × 6 = 24840,
123 × 4 × 56 = 27552,
123 × 45 × 6 = 33210,
1234 × 5 × 6 = 37020

其中乘法算式数值最大是第十种,为37020。

🔴题目大意

我们来看一下:

画的可能丑了一点, 但是我的电脑不是触屏。

但我们也可以看出在字符串123456中有5个可以插上*号的位置, 所以方案数就是C(N, S.size()-1)

🔴做法

#include<bits/stdc++.h>
using namespace std;
using LL = long long;
int m, len;
LL ans;
string s;
//dfs(k, st, res) : 前面已经产生的乘积为res,枚举第k个乘号添加在第st位数之后的情况 
void dfs(int k, int st, LL res){        if(k == m) {                        //如果已经使用了m个乘号 LL num = stoll(s.substr(st));    //在第m个乘号之后还有一个数字 ans = max(ans, res*num);        //计算所有数字乘积并与临时最大值比较,保存更大的值 return ;}for(int i = st; i < len-1; i++){    //枚举当前乘号的位置 //当前乘号的位置和上一次乘号位置的下一个就是新分离出来的数字 LL num = stoll(s.substr(st, i-st+1));    //从当前乘号位置的下一个开始搜索新的乘号的位置 dfs(k+1, i+1, res*num);            }return ;
}int main(){cin>>m>>s;len = s.length();dfs(0, 0, 1);                        //从下标0开始枚举乘号的位置 cout<<ans;return 0;
}

stoll就是stoi的long long版本 ,吧字符串变成long long int类型的十进制表示法。


 谢谢大家,这一期就完了。

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

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

相关文章

设计模式三:工厂模式

工厂模式包括简单工厂模式、工厂方法模式和抽象工厂模式&#xff0c;其中后两者属于23中设计模式 各种模式中共同用到的实体对象类&#xff1a; //汽车类&#xff1a;宝马X3/X5/X7&#xff1b;发动机类&#xff1a;B48TU、B48//宝马汽车接口 public interface BMWCar {void s…

Bert基础(一)--transformer概览

1、简介 当下最先进的深度学习架构之一&#xff0c;Transformer被广泛应用于自然语言处理领域。它不单替代了以前流行的循环神经网络(recurrent neural network, RNN)和长短期记忆(long short-term memory, LSTM)网络&#xff0c;并且以它为基础衍生出了诸如BERT、GPT-3、T5等…

2024全年放假日历表及调休安排 用手机便签设置放假倒计时

对于绝大多数的上班族来说&#xff0c;春节长假已经结束&#xff0c;现在要回归到正常的工作和生活中。为了给生活增加一些“盼头”&#xff0c;很多小伙伴不约而同打开手机日历&#xff0c;查看下个法定节假日是什么时候。下面给大家具体讲一下2024全年放假日历表及调休安排&a…

UE5 C++ 创建可缩放的相机

一.要将相机设置在Pawn类里 1.在MyPawn头文件里&#xff0c;加上摇臂和相机组件 #include "GameFramework/SpringArmComponent.h" #include "Camera/CameraComponent.h" 2.在Pawm里声明SceneComponet&#xff0c;SpringArmComponent,CameraComponent组件…

Excel生成不重复的UUID

第一步&#xff1a;在单元格中使用函数 第二步&#xff1a;下拉批量生成 生成函数如下&#xff1a; CONCATENATE(DEC2HEX(RANDBETWEEN(0,4294967295),8),DEC2HEX(RANDBETWEEN(0,42949),4),,DEC2HEX(RANDBETWEEN(0,42949),4),DEC2HEX(RANDBETWEEN(0,42949),4),DEC2HEX(RANDBETW…

Unity MVC开发模式与开发流程详解

在Unity游戏开发中&#xff0c;采用MVC&#xff08;Model-View-Controller&#xff09;模式是一种非常常见的设计模式。MVC模式将应用程序分为三个部分&#xff1a;模型&#xff08;Model&#xff09;、视图&#xff08;View&#xff09;和控制器&#xff08;Controller&#x…

vue3+element Plus+ts 自定义主题色,以及生成主题色各种透明度

目录 思路 安装css-color-function【接收一个颜色值&#xff0c;生成不同的透明度】 获取后台配置的主题色或者使用ColorPicker修改主题色 最终结果如下 思路 本篇文章的主体思路是从element Plus官网引申而来。结合了我以前用vue2element-ui配置主题色生成透明度&#x…

谈谈:你在工作中用到的设计模式!

谈谈:你在工作中用到的设计模式! Hello大家龙年好! 春节的假期转眼间过去,我们也要回归往日的节奏 因为最近和小伙伴们聊天发现,我们普遍在面试中,对被问起设计模式在工作中的应用,既有点熟悉,又有点陌生, 在网上看吧,又感觉鸡肋(为啥?不能解燃煤之急啊!哈哈),所以,为了打破这…

体验即王道:提升B端管理系统用户体验的10大法则

大家好&#xff0c;我是贝格前端工场&#xff0c;专注于前端开发和UI设计&#xff0c;有需求可以私信。本篇从用户体验角度来分析管理系统如何设计和开发。 一、用户体验的重要性 B端管理系统的用户体验对于企业的成功至关重要。 提高工作效率&#xff1a;一个好的用户体验可…

什么是网络安全?一文了解网络安全究竟有多重要!

随着互联网的普及和数字化进程的加速&#xff0c;网络安全已经成为我们生活中不可或缺的一部分。然而&#xff0c;很多人对于网络安全的概念仍然模糊不清。 那么&#xff0c;什么是网络安全&#xff1f;它究竟有多重要呢&#xff1f; 一、网络安全的定义 网络安全是指保护网络…

Sora一出 哪里又要裁员了?

上班前夕迎来大新闻&#xff0c;那就是Sora了&#xff0c;Sora是什么&#xff0c;有什么牛逼之处&#xff0c;怎么实现的&#xff0c;我们跟着官方文档透露出来的一点点信息&#xff0c;简单的捋一捋。 一、Sora是什么 官方给出的定义是&#xff1a;世界模拟器。这很明显有夸大…

js 多对象去重(多属性去重)

需求中发现后端可能没有处理重复数据&#xff0c;这个时候前段可以直接解决。 在 JavaScript 中&#xff0c;可以使用 Set 数据结构来进行多对象的去重。Set 是 ES6 新引入的集合类型&#xff0c;其特点是元素不会重复且无序。 下面是一个示例代码&#xff0c;展示如何通过 S…

three.js 物体下落动画(重力加速度)

效果&#xff1a; <template><div><el-container><el-main><div class"box-card-left"><div id"threejs" style"border: 1px solid red"></div><el-button click"loopFun"> 物体下落…

kubuntu 解决 kwallet 弹窗问题

问题 启动 kubuntu 后, 自动弹框要求验证 kwallet 的密码 查看本次启动中与 kwallet 有关的日志 $ journalctl -b | grep kwallet解决 开启 sddm/gdm 登录后自动解锁 kwallet 的功能 安装 kwallet-pam 模块 一般来说系统自带该模块 $ sudo apt install libpam-kwallet5 l…

机器学习基础(二)监督与非监督学习

导语&#xff1a;更深入地探讨监督学习和非监督学习的知识&#xff0c;重点关注它们的理论基础、常用算法及实际应用场景。 上一节我们深入探索机器学习的根本原理&#xff0c;包括基本概念、分类及如何通过构建预测模型来应用这些理论&#xff0c;详情可见&#xff1a; 机器学…

京东数据分析|京东销售数据怎么查|京东销售数据查询软件分享!

京东销售数据分析对商家来说具有多方面的重要作用&#xff0c;主要体现在以下几个方面&#xff1a; 市场趋势分析&#xff1a; 分析京东平台上的商品销量、销售额和价格走势等数据&#xff0c;可以帮助商家了解当前市场的整体需求趋势&#xff0c;以及不同品类的季节性变化、…

面向未来的全面预算管理,财务团队应具备的技能

当企业置身于当今这个瞬息万变的市场环境中时&#xff0c;每一次的数据分析和战略决策都至关重要。财务团队作为企业提升盈利能力和保持可持续发展的核心&#xff0c;不仅要适应不同的管理需求和不断变化的市场环境&#xff0c;还需要协助企业保持竞争优势和领先地位。经济世界…

「函数递归小课堂」~(C语言)

先赞后看&#xff0c;不足指正! 这将对我有很大的帮助&#xff01; 所属专栏&#xff1a;C语言知识 阿哇旭的主页&#xff1a;Awas-Home page 目录 引言 1. 什么是递归&#xff1f; 2. 递归的限制条件 3. 递归应用举例 3.1 求 n 的阶乘 3.2 图例演示 3.3 代码实现 4…

基于JAVA+SpringBoot+Vue的前后端分离的电影院售票管理运营平台

✌全网粉丝20W,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业项目实战✌ &#x1f345;文末获取项目下载方式&#x1f345; 一、项目背景介绍&#xff1a; 该系统研究背景聚焦于…

解密短视频上火爆的“私董会”现象

关注卢松松&#xff0c;会经常给你分享一些我的经验和观点。 最近“私董会”一词再一次上了热门&#xff0c;先是一夜暴火的商业博主dada管培生翻车暴雷&#xff0c;后面是三言财经、互联网大V纷纷发表了自己的看法。 国内领先的私董会服务机构通常每年的收费都在3万元起步。…