一些优雅的算法(c++)

求最大公约数:辗转相除法

int gcd(int a,int b){return b==0?a:gcd(b,a%b);
}

求最小公倍数:两整数之积除以最大公约数

int lcm(int a, int b){return a*b / gcd(a, b);
}

十进制转n进制:

char get(int x){if(x<=9){return x+'0';}else{return (x-10)+'A';}
}
string base(int x) // 十进制转 n进制
{string num;while(x){num += get(x % n), x /= n;}reverse(num.begin(),num.end());return num;
}

c语言输出

printf("%02d", a)

表示输出按俩位输出整形a,比如a=8,则输出08,a=24,输出24

printf("%.2f",a)

表示输出浮点数a小数点后俩位,比如a=8,则输出8.00,a=1.123,则输出a=1.12

最短路径问题

在这里插入图片描述

什么是链式前向星实现邻接表

链式前向星实现:设置三个数组,一个数组h用来存节点,一个数组e用来存值,一个数组ne用来存下一个节点。我们需要设置索引idx来实现ne的查找,不然没法链接起来

void add(int a,int b) {
e[idx]=b,ne[idx]=h[a],h[a]=idx++;
}

例:

!https://img-blog.csdnimg.cn/20200627104816311.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80NDQxNzQ3NQ==,size_16,color_FFFFFF,t_70我们遍历的话就是从h[1]开始遍历,此时h[1]=4,然后我们找下一个节点,下一个节点对应的索引就是3,再下一个节点对应的索引就是0,当索引为-1时结束。这个过程next实际上是向前走的,关系又是链式的,因此成为链式前向星

为什么要用memset(dist,0x3f,sizeof dist)来初始化

回答::0x3f3f3f3f的十进制是1061109567,是1e9级别的(和0x7fffffff一个数量级,0x7fffffff代表了32-bit int的最大值),而一般场合下的数据都是小于1e9的,所以它可以作为无穷大使用而不致出现数据大于无穷大的情形。 另一方面,由于一般的数据都不会大于10^9,所以当我们把无穷大加上一个数据时,它并不会溢出(这就满足了“无穷大加一个有穷的数依然是无穷大”),事实上0x3f3f3f3f+0x3f3f3f3f=2122219134,这非常大但却没有超过32-bit int的表示范围,所以0x3f3f3f3f还满足了我们“无穷大加无穷大还是无穷大”的需求。

floyd

E.路径(12届蓝桥杯c++B组第一场省赛)

小蓝学习了最短路径之后特别高兴,他定义了一个特别的图,希望找到图中的最短路径。
小蓝的图由 2021 个结点组成,依次编号 1 至 2021。
对于两个不同的结点 a, b,如果 a 和 b 的差的绝对值大于 21,则两个结点之间没有边相连;如果 a 和 b 的差的绝对值小于等于 21,则两个点之间有一条长度为 a 和 b 的最小公倍数的无向边相连。
例如:结点 1 和结点 23 之间没有边相连;结点 3 和结点 24 之间有一条无向边,长度为 24;结点 15 和结点 25 之间有一条无向边,长度为 75。
请计算,结点 1 和结点 2021 之间的最短路径长度是多少。
提示:建议使用计算机编程解决问题。

#include <iostream>
#include <cmath>
#include <cstring>
using namespace std;
const int N = 3000;
int n = 2021;
int g[N][N];
// 求最小公约数
int gcd(int a, int b) {return b ? gcd(b, a % b) : a;
}void floyb() {for (int t = 1; t <= n; ++ t) {for (int i = 1; i <= n; ++ i) {for (int j = 1; j <= n; ++ j) {g[i][j] = min(g[i][j], g[i][t] + g[t][j]);}}}
}
int main (){memset(g, 0x3f, sizeof g);for (int i = 1; i <= n; ++ i) {for (int j = 1; j <= n; ++ j) {if (abs(i - j) <= 21) {// 最大公倍数求法g[i][j] = i * j / gcd(i, j);}}}floyb();cout << g[1][n] << endl;return 0;
}

并查集

小蓝要用七段码数码管来表示一种特殊的文字。
在这里插入图片描述
上图给出了七段码数码管的一个图示,数码管中一共有 7 段可以发光的二 极管,分别标记为 a, b, c, d, e, f, g。
小蓝要选择一部分二极管(至少要有一个)发光来表达字符。在设计字符 的表达时,要求所有发光的二极管是连成一片的。
例如: b 发光,其他二极管不发光可以用来表达一种字符。
例如: c 发光,其他二极管不发光可以用来表达一种字符。这种 方案与上 一行的方案可以用来表示不同的字符,尽管看上去比较相似。
例如: a, b, c, d, e 发光, f, g 不发光可以用来表达一种字符。
例如: b, f 发光,其他二极管不发光则不能用来表达一种字符,因为发光 的二极管没有连成一片。
请问,小蓝可以用七段码数码管表达多少种不同的字符?
【答案提交】 这是一道结果填空的题,你只需要算出结果后提交即可。本题的结果为一个整数,在提交答案时只填写这个整数,填写多余的内容将无法得分。

#include<bits/stdc++.h>
using namespace std;
const int N=10;
int e[N][N],use[N],ans=0,fa[N];
int find(int f){//查找父值 if(fa[f]==f){return f;}return find(fa[f]);
}
void dfs(int n){if(n>7){for(int i=1;i<=7;i++){fa[i]=i;//每个元素单独成一个集合 }for(int i=1;i<=7;i++){//遍历每条边 for(int j=1;j<=7;j++){if(e[i][j]&&use[i]&&use[j]){//如果ij连通且都已打开,使它们的父集相等 int fx=find(i),fy=find(j);if(fx!=fy){fa[fx]=fy;//合并集合:即让它们的父值相等 }}}}int k=0;for(int i=1;i<=7;i++){ if(fa[i]==i&&use[i]){//判断现有元素有几个集合 k++;}}if(k==1){//如果已使用的灯在一个集合内:即父集只有一个元素 ans++;}return ;}use[n]=1;dfs(n+1);use[n]=0;dfs(n+1);
}
int main(){e[1][2]=e[1][6]=1;e[2][3]=e[2][7]=1;e[3][4]=e[3][7]=1;e[4][5]=1;e[5][6]=e[5][7]=1;e[6][7]=1;dfs(1);cout<<ans<<endl;return 0;
}

getline()

接收一个字符串,可以接收空格并输出,读取缓冲区的回车然后舍弃

#include<iostream>
#include<string>
using namespace std;
main ()
{
string str;
getline(cin,str);
cout<<str<<endl;
}

输入:jkljkljkl
输出:jkljkljkl
输入:jkl jfksldfj jklsjfl
输出:jkl jfksldfj jklsjfl

push_back()

push_back() 在Vector最后添加一个元素(参数为要插入的值)

vector<int> vec;
vec.push_back(10);
//在容器中添加10

或者再string中最后插入一个字符;

string str;
str.push_back('d');

类似的:

pop_back() //移除最后一个元素
clear()  //清空所有元素
empty() //判断vector是否为空,如果返回true为空
erase() // 删除指定元素

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

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

相关文章

2024Mathorcup数学应用挑战赛C题|图神经网络的预测模型+ARIMA时间序列预测模型+人员排班混合整数规划模型|完整代码和论文全解全析

2024Mathorcup数学应用挑战赛C题|图神经网络的预测模型ARIMA时间序列预测模型人员排班混合整数规划模型|完整代码和论文全解全析 我们已经完成了2024Mathorcup数学建模挑战赛C题的40页完整论文和代码&#xff0c;相关内容可见文末&#xff0c;部分图片如下&#xff1a; 问题分…

【MATLAB源码-第37期】matlab基于STBC(空时分组码)的MIMO系统误码率仿真。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 空时分组码&#xff08;Space-Time Block Code&#xff0c;简称STBC&#xff09;是一种在多输入多输出&#xff08;MIMO&#xff09;无线通信系统中用于提高数据传输可靠性的编码技术。MIMO技术利用多个发射和接收天线来同时…

自然语言控制机械臂:ChatGPT与机器人技术的融合创新(上)

引言&#xff1a; 自OpenAI发布ChatGPT以来&#xff0c;世界正迅速朝着更广泛地将AI技术融合到机器人设备中的趋势发展。机械手臂&#xff0c;作为自动化与智能化技术的重要组成部分&#xff0c;在制造业、医疗、服务业等领域的应用日益广泛。随着AI技术的进步&#xff0c;机械…

C语言.指针(5)

指针&#xff08;5&#xff09; 1.sizeof和strlen的对比1.1sizeof1.2strlen1.3sizeof和strlen的对比 2.数组和指针笔试题解析2.1一维数组2.2字符数组2.3二维数组 3.指针运算笔试题解析3.1 题目13.2 题目23.3 题目33.4 题目43.5 题目53.6 题目63.7 题目7 1.sizeof和strlen的对比…

聊一聊分库分表(是什么?怎么分?有什么坑?)

目录 为什么会分表分库&#xff1f; 数据分表 怎么分表&#xff1f; 垂直分表 好处&#xff1a; 缺点&#xff1a; 水平分表 优点&#xff1a; 缺点&#xff1a; 数据分库 怎么分库&#xff1f; 水平分库 适用场景&#xff1a; 优点&#xff1a; 注意事项&#x…

Python程序设计 上下文管理器

上下文管理器 如果你有阅读源码的习惯&#xff0c;可能会看到一些优秀的代码经常出现带有 “with” 关键字的语句&#xff0c;它通常用在什么场景呢&#xff1f; 对于系统资源如文件、数据库连接、socket 而言&#xff0c;应用程序打开这些资源并执行完业务逻辑之后&#xff…

中科方德服务器操作系统安装zabbix5.0

原文链接&#xff1a;中科方德服务器操作系统安装zabbix5.0 Hello&#xff0c;大家好啊&#xff01;接着我们上一次的讨论&#xff0c;今天我要为大家介绍如何在已经安装好的中科方德服务器操作系统基础上&#xff0c;安装和配置Zabbix 5.0。Zabbix是一个开源的监控软件工具&am…

LeetCode-416. 分割等和子集【数组 动态规划】

LeetCode-416. 分割等和子集【数组 动态规划】 题目描述&#xff1a;解题思路一&#xff1a;01背包问题&#xff0c;动规五部曲解题思路二&#xff1a;0解题思路三&#xff1a;0 题目描述&#xff1a; 给你一个 只包含正整数 的 非空 数组 nums 。请你判断是否可以将这个数组分…

Vue异步组件,深入解析

基本用法​ 在大型项目中&#xff0c;我们可能需要拆分应用为更小的块&#xff0c;并仅在需要时再从服务器加载相关组件。Vue 提供了defineAsyncComponent方法来实现此功能&#xff1a; import { defineAsyncComponent } from vueconst AsyncComp defineAsyncComponent(() >…

贪心算法|738.单调递增的数字

力扣题目链接 class Solution { public:int monotoneIncreasingDigits(int N) {string strNum to_string(N);// flag用来标记赋值9从哪里开始// 设置为这个默认值&#xff0c;为了防止第二个for循环在flag没有被赋值的情况下执行int flag strNum.size();for (int i strNum.…

Open3D生成规则点云(二)

一、代码 Python import open3d as o3d import numpy as np# 定义正方体的参数 def create_square(x1=0, y1=0, z1=0, side_length=1, resolution=20):vertices = []for i in range(resolution):for j in range(resolution):for k in range(resolution):x = x1 + i * side_le…

2020 年 9 月青少年软编等考 C 语言一级真题解析

目录 T1. 输出整数思路分析 T2. 新冠疫情死亡率思路分析 T3. 有一门课不及格的学生T4. 整数的个数思路分析 T5. 金币 T1. 输出整数 输入四个整数&#xff0c;把输入的第三、第四个整数输出。 时间限制&#xff1a;1 s 内存限制&#xff1a;64 MB 输入 只有一行&#xff0c;共…

python爬虫 - 下载图片

文章目录 1、下载图片示例1&#xff1a;使用 .urlretrieve() 函数2、下载图片示例2 - 使用 open/write 函数3、下载图片示例33.1 使用 open/write 下载3.2 使用 urlretrieve下载 爬虫的本质&#xff1a;模拟对应的App&#xff0c;浏览器访问对应的地址获取到数据 1、下载图片示…

考虑预同步的虚拟同步机T型三电平逆变器并离网MATLAB仿真模型

微❤关注“电气仔推送”获得资料&#xff08;专享优惠&#xff09; 模型简介 三相 T 型三电平逆变器电路如图所示&#xff0c;逆变器主回路由三个单相 T 型逆变器组成。 直流侧输入电压为 UPV&#xff0c;直流侧中点电位 O 设为零电位&#xff0c;交流侧输出侧是三相三线制连…

高防虚拟主机的重要性

在当今数字化时代&#xff0c;网络安全已经成为企业和个人必须面对的重要议题。随着网络攻击手段的不断升级和多样化&#xff0c;传统的虚拟主机已经难以满足日益增长的安全需求。在这样的背景下&#xff0c;高防虚拟主机应运而生&#xff0c;成为保护网站安全、抵御网络攻击的…

4.双向循环链表的模拟实现

1.双向链表的实现 1.1双向链表节点的结构声明 typedef int LTDataType;typedef struct ListNode {struct ListNode* prev; // 指向该节点的前一个节点struct ListNode* next; // 指向该节点的后一个节点LTDataType data; // 该节点中存储的数据 }LTNode; // 将这…

Linux内核errno-base.h源码分析

上次写过一个博客&#xff0c;主要关于内核错误相关的源码分析&#xff08;链接&#xff09;&#xff0c;最近突然发现上次的分析不完善&#xff0c;因此本次完善相关分析。 Linux内核中经常见到一些返回值&#xff0c;如-12&#xff0c;比如下面是我遇到过的一个截图&#xff…

【Java面试题】MySQL上篇(索引)

文章目录 索引1.索引的分类&#xff1f;2.B树和B树的区别&#xff1f;2.1B树2.2B树 3.为什么使用索引会加快查询&#xff1f;4.创建索引的注意点&#xff1f;5.索引在哪些情况下会失效&#xff1f;6.聚簇索引和非聚簇索引的区别&#xff1f;7.回表查询是什么&#xff1f;8.什么…

阿里云租用服务器GPU配置报价单_1年_一个月_1小时价格表

阿里云GPU服务器租用价格表包括包年包月价格、一个小时收费以及学生GPU服务器租用费用&#xff0c;阿里云GPU计算卡包括NVIDIA V100计算卡、T4计算卡、A10计算卡和A100计算卡&#xff0c;GPU云服务器gn6i可享受3折优惠&#xff0c;阿里云服务器网aliyunfuwuqi.com分享阿里云GPU…

机器学习—概述(一)

什么是机器学习 数据 模型 预测 从历史数据当中获得规律?这些历史数据是怎么的格式? 数据集构成 特征值&#xff0b;目标值 机器学习算法分类 监督学习 目标值:类别一分类问题 k-近邻算法、贝叶斯分类、决策树与随机森林、逻辑回归目标值:连续型的数据一回归问题 线性回…