C++学习笔记3

A. 求出那个数

题目描述

喵喵是一个爱睡懒觉的姑娘,所以每天早上喵喵的妈妈都花费很大的力气才能把喵喵叫起来去上学。

在放学的路上,喵喵看到有一家店在打折卖闹钟,她就准备买个闹钟回家叫自己早晨起床,以便不让妈妈这么的辛苦。但是想到自己睡觉睡的太死了,一个闹钟可能并不能够把自己叫醒,所以她决定买一些闹钟回家一起用。

但是 n n n 个闹钟的音量并不是一个闹钟音量的 n n n 倍,而是存在一个很奇怪的数学关系:

a n = { 1 n ≤ 2 a n − a n − 1 + a n − 1 − a n − 2 n > 2 a_n=\begin{cases} 1 & n\le2 \\ a_{n-a_{n-1}}+a_{n-1-a_{n-2}} & n>2 \end{cases} an={1anan1+an1an2n2n>2

现在喵喵想请你帮忙计算 n n n 个闹钟的音量会有多大,请你写个程序帮忙计算。

输入格式

多组输入。

每组输入在一行中给出一个正整数 n n n

n = 0 n=0 n=0 时表示输入结束。

  • 1 ≤ n ≤ 1 0 6 1\le n\le10^6 1n106

输出格式

每组输入在一行中输出 n n n 个闹钟的音量总和。

样例

输入 #1

1
2
3
5
10
0

输出 #1

1
1
2
3
6
  1. 按照题目的要求递推过去即可。
#include <bits/stdc++.h>
using namespace std;

int a[1000010];

void solve()
{
	int _;
	cin >> _;
	while (_)
	{
		cout << a[_] << '\n';
		cin >> _;
	}
}

signed main()
{
	a[1] = a[2] = 1;
	for (int i = 3;i <= 1000000;i++)
	{
		a[i] = a[i-a[i-1]]+a[i-1-a[i-2]];
	}
	int TTT;
//	cin >> TTT;
	TTT = 1;
	while (TTT--) solve();
	return 0;
}

B. 加密通话

题目描述

在这个信息十分发达的时代,喵喵十分担心自己发送的消息被黑客拦截,因此他决定将内容加密。她和同学一起发明了一种加密方法,因为他们要加密的文字只有大写字母和空格,所以她们一起约定空格编号就是 0 0 0 A A A 标号就是 1 1 1 … \dots Z Z Z 编号就是 26 26 26,然后再将每个编号转为长度为 5 5 5 的二进制数以后,按照螺旋方阵的方式填入一个 R × C R\times C R×C 的矩阵中,若二进制串不够长就在后面补 0 0 0

例如 R = 4 , C = 4 R=4,C=4 R=4,C=4 时,加密 BEE B = 00010 , E = 00101 , E = 00101 B=00010,E=00101,E=00101 B=00010,E=00101,E=00101。末尾补零填进矩阵后是这样:

0001
0100
0010
1010

然后我们再将矩阵中的元素一行一行的取出来,得到加密后的信息就是
0001010000101010 0001010000101010 0001010000101010。如果通信全靠手算的话,那就急死人了,现在先请你来实现一个加密程序来将信息进行加密。

输入格式

输入仅在一行中给出 R , C R,C R,C,以及要加密的字符串 S S S

保证 R , C R,C R,C 不会超过 20 20 20,且 R × C R\times C R×C 不会小于五倍的字符串的长度。

S S S 中可能含有空格!

输出格式

在一行中输出加密后的结果。

样例

输入 #1

4 4 BEE

输出 #1

0001010000101010
  1. 注意输入有空格
  2. 转二进制之后不足五位前面要补零
  3. 整个二进制串长度不足 R × C R\times C R×C 末尾要补零
  4. 最后填进矩阵遍历即可
#include <bits/stdc++.h>
//#define int long long
using namespace std;

int n,m;
string s;
map <char,string> mp;
string str;

const int fx[4] = {0,1,0,-1},fy[4] = {1,0,-1,0};
char ans[100][100];

void solve()
{
	cin >> n >> m;
	getchar(); //别忘了把 n,m 之后的空格读入进来 
	getline(cin,s);
	mp[' '] = "00000";
	mp['a'] = "00001";
	mp['b'] = "00010";
	mp['c'] = "00011";
	mp['d'] = "00100";
	mp['e'] = "00101";
	mp['f'] = "00110";
	mp['g'] = "00111";
	mp['h'] = "01000";
	mp['i'] = "01001";
	mp['j'] = "01010";
	mp['k'] = "01011";
	mp['l'] = "01100";
	mp['m'] = "01101";
	mp['n'] = "01110";
	mp['o'] = "01111";
	mp['p'] = "10000";
	mp['q'] = "10001";
	mp['r'] = "10010";
	mp['s'] = "10011";
	mp['t'] = "10100";
	mp['u'] = "10101";
	mp['v'] = "10110";
	mp['w'] = "10111";
	mp['x'] = "11000";
	mp['y'] = "11001";
	mp['z'] = "11010";
	for (int i = 0;i < s.size();i++) str += mp[tolower(s[i])];
	for (int i = 0;i < 100;i++) for (int j = 0;j < 100;j++) ans[i][j] = '.';
	while (str.size() < n*m) str = str + '0';
	int x = 0,y = 0;
	int d = 0;
	for (int i = 0;i < n*m;i++)
	{
		ans[x][y] = str[i];
		int xx = x + fx[d];
		int yy = y + fy[d];
		if (xx < 0 || xx >= n || yy < 0 || yy >= m || ans[xx][yy] != '.')
		{
			d = (d+1) % 4;
			xx = x + fx[d];
			yy = y + fy[d];
		}
		x = xx;
		y = yy;
	}
	for (int i = 0;i < n;i++) for (int j = 0;j < m;j++) cout << ans[i][j];
}

signed main()
{
	int TTT;
//	cin >> TTT;
	TTT = 1;
	while (TTT--) solve();
	return 0;
}

C. 换零钱

题目描述

喵喵现在有一堆硬币,这么多的硬币带在身上沉甸甸的,所以她不想要这么多硬币,于是乎她在想怎么在付款的时候一次性付出更多个数的硬币。这天喵喵在柜台结账的时候,她突然想到如果自己多付一些钱让老板找零,可能会让自己硬币的个数更少。老板为了更好的给客人找零,他一定会用最少的硬币数量找零给客人。

这样,喵喵开始思考该付给老板多少钱,才能在付完钱之后手里的硬币数量最少。可惜的是,喵喵在计算这方面一直不太擅长,就请你来帮助喵喵解决这个烦恼吧。

输入格式

输入一共有 3 3 3 行。

第一行表示要付的价格。

第二行有 5 5 5 个数字 p 1 , p 5 , p 10 , p 20 , p 50 p_1,p_5,p_{10},p_{20},p_{50} p1,p5,p10,p20,p50,分别是东东钱包里面一元、五元、十元、二十元和五十元硬币的个数。

第三行有 5 5 5 个数字 p 1 , p 5 , p 10 , p 20 , p 50 p_1,p_5,p_{10},p_{20},p_{50} p1,p5,p10,p20,p50,是老板所拥有的一元、五元、十元、二十元和五十元硬币的个数。

你可以假设喵喵身上的钱足够来付账,而且至少有一种付钱的方法使得老板可以找得开(如果需要找零的话)。

输出格式

在一行中输出一个正整数表示付完钱剩余的硬币个数。

样例

输入 #1

25
0 3 2 2 3 
1 1 1 1 1

输出 #1

4

提示

3 3 3 5 5 5 元, 2 2 2 10 10 10 元, 2 2 2 20 20 20 元,老板找回 1 1 1 50 50 50 元,最后手里有 4 4 4 个硬币。

直接把所有的钱付给老板,然后让老板往回找。

#include <bits/stdc++.h>
//#define int long long
using namespace std;

const int inf = 1e9;

int n;
int a[10];
int b[10];

const int coin[6] = {0,1,5,10,20,50};
int ans,dp[1000010];

int sum; //现有的钱 

void solve()
{
	cin >> n;
	for (int i = 1;i <= 5;i++) cin >> a[i],sum += a[i] * coin[i];
	for (int i = 1;i <= 5;i++) cin >> b[i],b[i] += a[i]; //先付钱
	sum -= n; //付完前后还剩 sum 元
	for (int i = 1;i <= sum;i++) dp[i] = inf;
	for (int i = 5;i >= 1;i--) //尽量取大的 
	{
		//理论上能拿到的最多的 和 老板有的
		int num = min(sum/coin[i],b[i]);
		for (int k = 1;num > 0;k *= 2)
		{
			if (k > num) k = num; //取最多
			num -= k; //还剩的
			for (int j = sum;j >= coin[i] * k;j--)
				dp[j] = min(dp[j],dp[j-coin[i]*k]+k);
		}
	}
	cout << dp[sum];
}

signed main()
{
	int TTT;
//	cin >> TTT;
	TTT = 1;
	while (TTT--) solve();
	return 0;
}

D. 紧急排水

题目描述

由于气候变暖,许多地方都出现了历史上从未有过的大暴雨,造成了巨大的损失。为了排出各个地区的积水,国家紧急召集了有相关经验的科学家和工程师们组成了救灾小队,小队成员经过讨论后决定利用地形优势来制定排水方案。经过勘测,可以得到地表各区域的高度,如下高度表和三维图。

在这里插入图片描述

高度表中的数字代表高低,相邻(有边相接)的格子不会有相同的高度。为了尽快消除积水,得最大限度的利用排水设备进行作业。若一个格子有排水装备,则该格子排水所需时间为 0 0 0,没有排水装备的格子只需要等水流到有排水装备的格子,水能往相邻且较低的格子流动,流动到相邻一格的时间为 1 1 1。若某个格子的水能流到不止一个具有排水装备的格子,则让其流向最近的一个。

为了避免排水装备的不合理安置,任两个排水装备所在的格子之间的水不能流通,也就是说任何有排水装备的格子的水不可能流到另一个有装备的格子。

假设安装了 3 3 3 个排水设备在地图上,为了尽快排完所有的水,其中一种方案是装在三维图中的灰色格子上,这样各个格子所需要的排水时间下:
在这里插入图片描述

输入格式

第一行输入两个正整数 n , m n,m n,m 代表地图为 n × n n\times n n×n,最多安装 m m m 个排水设备。

接下来 n n n 行,每行有 n n n 个数字表示格子的高度 d d d

  • 1 ≤ n ≤ 500 , 1 ≤ m ≤ 1000 1\le n\le500,1\le m\le1000 1n500,1m1000
  • 0 < d < 2 31 0<d<2^{31} 0<d<231

输出格式

在一行中输出排水所需最短时间。

若需要超过 m m m 个排水装备才能将所有格子都排水,输出 Impossible

样例

输入 #1

3 9
3 2 3
2 1 2
3 2 3

输出 #1

2

输入 #2

4 3
5 3 2 3
4 2 1 2
5 3 2 3
4 2 3 2

输出 #2

3

输入 #3

3 1
1 2 3
2 1 2
3 2 3

输出 #3

Impossible
  1. 安装排水设备的个数等于坑的个数,多少个坑多少个设备,如果坑数大于 m m m 就是 Impossible
  2. 坑是指比周围格子都低的格子
  3. 然后从坑往外一圈一圈的搜,取最大值就行了
#include <bits/stdc++.h>
#define int long long
using namespace std;

int a[510][510];
int f[510][510];
int mx,cnt;
int n,m;

const int fx[4] = {-1,0,0,1},fy[4] = {0,-1,1,0};

int low(int x,int y)
{
	for (int i = 0;i < 4;i++)
	{
		int xx = x + fx[i],yy = y + fy[i];
		if (xx >= 0 && xx < n && yy >= 0 && yy < n && a[x][y] > a[xx][yy])
			return 0;
	}
	return 1;
}

struct node {int x,y,d;};
queue <node> q;

void bfs()
{
	while (!q.empty())
	{
		int x = q.front().x,y = q.front().y,d = q.front().d;
		q.pop();
		for (int i = 0;i < 4;i++)
		{
			int xx = x + fx[i],yy = y + fy[i];
			if (xx >= 0 && xx < n && yy >= 0 && yy < n && !f[xx][yy] && a[x][y] < a[xx][yy])
			{
				q.push({xx,yy,d+1});
				f[xx][yy] = 1;
				mx = max(mx,d+1);
			}
		}
	}
}

void solve()
{
	cin >> n >> m;
	for (int i = 0;i < n;i++)
		for (int j = 0;j < n;j++)
			cin >> a[i][j];
	for (int i = 0;i < n;i++)
		for (int j = 0;j < n;j++)
			if (low(i,j))
				cnt++,f[i][j] = 1,q.push({i,j,0}); //坑
	if (cnt > m) cout << "Impossible";
	else bfs(),cout << mx;
}

signed main()
{
	int TTT = 1;
//	cin >> TTT;
	while (TTT--) solve();
	return 0;
}

E. 倒酒

题目描述

喵喵是一个商人,主营业务是卖酒,做生意初期,一切以节省开支为第一要务,所以她除了装酒的大桶外只买了两个杯子,这两个杯子除了标注了装满时是装了多少,并没有其它刻度。

每当有客人光顾的时候,客人会告诉喵喵他想要买多少酒。虽然没有正常的容器,但是聪明的喵喵会利用这两个杯子的差异,经过若干次倒空与注满的操作,准确的凑出客人所需要的量。

经过多日经营,喵喵也发现了一个问题,有些客人的需求,喵喵是无论如何也凑不出来的,这个时候她就会提议让客人多买一点或者少买一点到恰好能凑出的量。

每次到最后才发现凑不出来所需要的量真的是让喵喵有点头疼,所以喵喵求助于你让你能不能最开始的时候就判断出客人的量能不能被准确凑出。

输入格式

多组输入。

每组输入给出三个不超过 100 100 100 的正整数 x , y , z x,y,z x,y,z,分别表示喵喵的两个杯子和客人需要的量。

一行中 0 0 0 的时候表示输入结束。

输出格式

对每组测试资料,你应该输出一行。如果客人要求的量凑得出来,请输出 Yes,否则请输出 No

样例 #1

样例输入 #1

1 2 1
1 2 9
3 5 4
3 6 8
0 0 0

样例输出 #1

Yes
Yes
Yes
No
  1. 两个杯子的容量 x , y x,y x,y,假设 x > y x>y x>y,那我们相当于是有抽象的杯子 k 1 × ( x − y ) k_1\times(x-y) k1×(xy),也有抽象的杯子 k 2 × y − x k_2\times y-x k2×yx k 1 , k 2 k_1,k_2 k1,k2 都是任意常数
  2. 所以题目相当于是求 k 1 × ( x − y ) + k 2 × y − x = z k_1\times(x-y)+k_2\times y-x=z k1×(xy)+k2×yx=z 的解
  3. 合并可得 k 3 × x − k 4 × y = z k_3\times x-k_4\times y=z k3×xk4×y=z k 3 , k 4 k_3,k_4 k3,k4 是任意常数
  4. 上面这个方程有解的条件就是 z   m o d   gcd ⁡ ( x , y ) = 0 z\bmod\gcd(x,y)=0 zmodgcd(x,y)=0
#include <bits/stdc++.h>
#define int long long
using namespace std;

void solve()
{
	int a,b,c;
	while (cin >> a >> b >> c)
	{
		if (a + b + c == 0) return ;
		if (c % __gcd(a,b) == 0) cout << "Yes\n";
		else cout << "No\n";
	}
}

signed main()
{
	solve();
	return 0;
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

创新点!CNN与LSTM结合,实现更准预测、更快效率、更高性能!

推荐一个能发表高质量论文的好方向&#xff1a;LSTM结合CNN。 LSTM擅长捕捉序列数据中的长期依赖关系&#xff0c;而CNN则擅长提取图像数据的局部特征。通过结合两者的优势&#xff0c;我们可以让模型同时考虑到数据的时序信息和空间信息&#xff0c;减少参数降低过拟合风险&a…

STM32_HAL_RTC_解决恢复电源时再一次初始化

1问题 板子再次恢复电源时直接初始化了时间 2解决思路 在初始化函数&#xff08;MX_RTC_Init();&#xff09;中增加判断&#xff0c;判断是否是二次初始化 将值放入备份存储其中 3问题图 4解决后的源码 /* RTC init function */ void MX_RTC_Init(void) {/* USER CODE BE…

C++青少年简明教程:C++数据类型

C青少年简明教程&#xff1a;C数据类型 数据类型定义了变量可以存储哪些类型的数据&#xff0c;以及对这些数据可以进行哪些操作。C提供了丰富的数据类型供开发者使用。 下面是 C 中常见的数据类型&#xff1a; ★整型&#xff08;int&#xff09;&#xff1a;整数类型的数据…

零一万物发布千亿参数模型Yi-Large,李开复呼吁关注TC-PMF,拒绝Ofo式烧钱打法

5月13日&#xff0c;在零一万物成立一周年之际&#xff0c;零一万物 CEO 李开复博士携带千亿参数 Yi-Large 闭源模型正式亮相&#xff0c;正式进军全球 SOTA 顶级大模型之首&#xff0c;在斯坦福最新的 AlpacaEval 2.0 达到全球大模型 Win Rate 第一。除此之外&#xff0c;零一…

【代码随想录】【动态规划】背包问题 - 完全背包

完全背包 模板&#xff1a;完全背包问题 问题描述 完全背包问题与01背包问题唯一的区别在于&#xff1a; 在01背包中&#xff1a;每个物品只有一个&#xff0c;要么放入背包&#xff0c;要么不放入背包在完全背包中&#xff1a;每个物品有无限多个&#xff0c;可以不放入背…

迪安诊断数智中心战略与PMO负责人徐黎明受邀为第十三届中国PMO大会演讲嘉宾

全国PMO专业人士年度盛会 迪安诊断技术集团股份有限公司数智中心战略与PMO负责人徐黎明先生受邀为PMO评论主办的2024第十三届中国PMO大会演讲嘉宾&#xff0c;演讲议题为“软件研发项目管理指标体系建设实践”。大会将于6月29-30日在北京举办&#xff0c;敬请关注&#xff01; …

Rx(Reactive Extensions)的由来

既然我们已经介绍了响应式编程&#xff0c;现在是时候了解我们的明星了:响应式扩展&#xff0c;通常简称为Rx。微软开发了Reactive扩展库&#xff0c;使其易于处理事件流和数据流。在某种程度上&#xff0c;时变值本身就是一个事件流;每个值更改都是一种类型的事件它会更新依赖…

电流反馈型运放设计要点总结

目录 前言 基本架构 CFB和VFB运算放大器的差异 总结&#xff1a;电流反馈(CFB)与电压反馈(VFB) 前言 最近一个项目用到THS3491&#xff0c;发生了震荡&#xff0c;这是一个电流型反馈运放&#xff0c;借此机会&#xff0c;温故一下&#xff0c;电流运放的相关设计知识 基本架…

JAVA远程调试步骤

1.生成参数 2.复制到启动命令中 3.打jar包运行到远程服务器中 4.开始远程调试

【数据结构与算法 刷题系列】环形链表的约瑟夫问题

&#x1f493; 博客主页&#xff1a;倔强的石头的CSDN主页 &#x1f4dd;Gitee主页&#xff1a;倔强的石头的gitee主页 ⏩ 文章专栏&#xff1a;数据结构与算法刷题系列&#xff08;C语言&#xff09; 目录 一、问题描述 二、解题思路详解 解题思路 解题步骤 三、C语言代码…

NSSCTF | [LitCTF 2023]我Flag呢?

这道题没啥好说的&#xff0c;题目标签为源码泄露&#xff0c;我们直接CtrlU查看网页源码就能在最后找到flag 本题完

Linux---windows 机器和远端的 Linux 机器如何通过 XShell 传输文件

一、关于rzsz 这个工具用于 windows 机器和远端的 Linux 机器通过 Xshell 传输文件. 二、下载rzsz软件 用root输入命令&#xff1a; sudo yum install -y lrzsz下载完成&#xff1a; 三、如何传输 有图形化界面 1、从Windows机器传输给远端Linux机器 ① 直接拖拽 直接将…

从编辑器角度来理解定义和声明

报错,在函数里面(包括int main函数)extern声明会和定义冲突 下面这种写法就很ok 静态变量的反汇编 #include<iostream> using namespace std; extern int c; int ma

Mysql与Java连接----JDBC

前言: 当将Java与MySQL数据库连接时&#xff0c;JDBC&#xff08;Java Database Connectivity&#xff09;是一种重要的技术。JDBC允许Java应用程序通过标准的数据库访问方式与不同的关系型数据库进行通信&#xff0c;其中包括MySQL。通过使用JDBC&#xff0c;Java开发人员可以…

ICode国际青少年编程竞赛- Python-5级训练场-多参数函数

ICode国际青少年编程竞赛- Python-5级训练场-多参数函数 1、 def go(a, b):Spaceship.step(2)Dev.step(a)Spaceship.step(b)Dev.turnRight()Dev.step(b)Dev.turnLeft()Dev.step(-a) Dev.turnLeft() Dev.step(3) Dev.step(-3) go(3, 2) go(6, 1) go(5, 2) go(4, 3)2、 def go(…

processing完整教程

概述&#xff1a;processing在我眼里就是libgdx的高度封装&#xff0c;如果各位会libgdx&#xff0c;学processing应该可以说是无师自通&#xff0c;当然processing是java语言那边的。 processing是什么&#xff1f; 官网是这样解释的&#xff1a;Processing 是一本灵活的软件…

快速判断出485从站设备是否支持MODBUS RTU无线通讯

对于变频器和仪表设备&#xff0c;都支持485串口通讯&#xff0c;那么怎么判断从站设备支持那种协议呢&#xff1f;通常分为两种方式去判断&#xff1a;1.从设备参数参看2.从设备通讯报文查看。本次文章以以台达MH300系列变频器为例。 1.从设备通讯参数查看 使用设备之前一定…

C语言 文件操作

目录 1. 什么是文件&#xff1f;2. 二进制文件和文本文件3. 文件的打开和关闭3.1 流和标准流3.1.1 流3.1.2 标准流 3.2 文件指针3.3 打开、关闭文件3.3.1 fopen - 打开文件3.3.2 fclose - 关闭文件 4. 文件的顺序读写4.1 fgetc - 从文件流获取一个字符4.2 fputc - 将一个字符写…

金融业开源软件应用 评估规范

金融业开源软件应用 评估规范 1 范围 本文件规定了金融机构在应用开源软件时的评估要求&#xff0c;对开源软件的引入、维护和退出提出了实现 要求、评估方法和判定准则。 本文件适用于金融机构对应用的开源软件进行评估。 2 规范性引用文件 下列文件中的内容通过文中的规范…

智能制造数字工厂未来三年规划方案(80页ppt下载)

一、资料介绍 智能制造数字工厂未来三年规划方案是一份全面而深入的战略性文件&#xff0c;旨在指导我们公司在未来三年内实现智能制造领域的跨越式发展。这份80页的PPT资料&#xff0c;以“智能制造、智能制造系统、数字化工厂、数字孪生工厂、智能工厂和数字化车间”为核心关…