2.17C语言学习

P1678 烦恼的高考志愿

写完后发现题解里面用的是优先队列或者二分什么的,其实这个题可以贪心,我们把学校的分数线和学生的成绩分别进行排序,然后从前往后遍历,每次比较当前学校的分数与学生成绩的差距和下一个学校的分数与学生成绩之间的差距,如果前面那个小就把他加进sum,遍历完所有学生即可得出答案,记得有一点就是遍历下一个学生时,学校不往后推,不然结果会错误

#include<bits/stdc++.h>
using namespace std;
int a[100009],b[100009];
long long sum=0;
int main(){int n,m;scanf("%d %d",&n,&m);for(int i=1;i<=n;i++){scanf("%d",&a[i]);}for(int j=1;j<=m;j++){scanf("%d",&b[j]);}sort(a+1,a+1+n);sort(b+1,b+1+m);a[n+1]=100000000;int flag=1;for(int i=1;i<=n;i++){if(flag==m+1)break;if(abs(a[i]-b[flag])<abs(a[i+1]-b[flag])){//	printf("%d %d\n",a[i],b[flag]);sum+=abs(a[i]-b[flag]);i--;flag++;}}printf("%lld",sum);	return 0;
}

P1364 医院设置

每个医院都可以看成是一个节点,本题需要创造一个树,接着以每一个节点为起点遍历,用dfs对树进行遍历,记录每次结果的最小值,最后得到答案dfs,注意遍历顺序

#include<bits/stdc++.h>
using namespace std;
struct node{int human;int left;int right;int father;
};
node tree[1000];
int vis[105],n,sum,ans=INT_MAX;
void dfs(int step,int pos){sum+=step*tree[pos].human;int fa=tree[pos].father,left=tree[pos].left,right=tree[pos].right;if(fa&&!vis[fa]){vis[fa]=1;dfs(step+1,fa);}if(left&&!vis[left]){vis[left]=1;dfs(step+1,left);}if(right&&!vis[right]){vis[right]=1;dfs(step+1,right);}
}
int main(){scanf("%d",&n);for(int i=1;i<=n;i++){scanf("%d %d %d",&tree[i].human,&tree[i].left,&tree[i].right);tree[tree[i].left].father=i;tree[tree[i].right].father=i;}for(int i=1;i<=n;i++){sum=0;memset(vis,0,sizeof(vis));vis[i]=1;dfs(0,i);ans=min(ans,sum);}printf("%d",ans);return 0;
}

P1258 小车问题

昨天提到的小车问题的正解是二分,但是我图简单用的数学方法

首先,每个人都要做一次车,而且两个人要同时到达,这样才能使总时间最短。

那么,我们设起点为A,终点为B,小车先带甲开到C点后甲下车走到B点,同时小车掉头与已经走到D点的乙相向而行,相遇于点E,最后小车带乙向B开去,和甲同时到达。

现在设AC=S

则:

#include<bits/stdc++.h>
using namespace std;
int main()
{double s,s1,s2,v1,v2,t1,t2,p;double a,b;scanf("%lf%lf%lf",&s,&v1,&v2);s1=0;s2=s;do{p=(s1+s2)/2.0;a=p/v2;b=(p-a*v1)/(v1+v2);t1=a+(s-p)/v1;t2=a+b+(s-(a+b)*v1)/v2;if(t1<t2)s2=p;elses1=p;}while(fabs(t1-t2)>1e-8);printf("%.6lf",t1);return 0;
}

一、二叉树
二叉树(Binary Tree)是一种重要的树状数据结构,它由节点构成,每个节点最多有两个子节点:一个左子节点和一个右子节点。这种结构使得二叉树在计算机科学和编程中具有广泛的应用。

1.1 二叉树的基本特性:
根节点:二叉树的顶部节点称为根节点,它是树的起点。
子树:树中的任何节点都可以作为根节点形成子树。
父节点和子节点:节点可以有零、一个或两个子节点。父节点指向子节点。
叶子节点:没有子节点的节点称为叶子节点。
深度:从根节点到某个节点的路径长度称为深度。根节点深度为0。
高度:树中最深节点的深度称为树的高度。
层次:节点的深度加1就是该节点所在的层次。
1.2 二叉树的常见类型:
二叉搜索树(Binary Search Tree,BST):一种有序二叉树,左子树上的节点值小于根节点,右子树上的节点值大于根节点,这个性质使得二叉搜索树用于快速查找、插入和删除操作。
平衡二叉树:一种特殊的二叉搜索树,保持树的左右子树高度差不超过1,以保持查找操作的高效性能。常见的平衡二叉树包括AVL树和红黑树。
二叉堆(Binary Heap):一种特殊的二叉树结构,通常用于实现堆排序和优先队列。有最大堆和最小堆两种类型。
1.3 二叉树的遍历方式:
前序遍历(Preorder Traversal):先访问根节点,然后依次遍历左子树和右子树。
中序遍历(Inorder Traversal):先遍历左子树,然后访问根节点,最后遍历右子树。对于二叉搜索树,中序遍历的结果是有序的。
后序遍历(Postorder Traversal):先遍历左子树,然后遍历右子树,最后访问根节点。
层次遍历(Level Order Traversal):按层次从上到下,从左到右遍历树的节点。

二、图的基本概念
图(Graph)是一种抽象数据结构,用于表示多个对象之间的关系。图是计算机科学中非常重要的数据结构,用于解决许多实际问题。以下是图的基本概念:

节点(Node 或 Vertex):图中的基本元素,通常表示一个实体或对象。节点可以有不同的属性和类型,具体取决于应用。节点可以包含有关实体的信息,如名称、权重等。
边(Edge 或 Arc):图中连接两个节点的线,表示节点之间的关系。边可以是有向的(从一个节点到另一个节点)或无向的(没有方向)。通常,边可能具有权重,用于表示关系的强度或成本。
顶点数(Vertex Count):图中节点的总数。
边数(Edge Count):图中边的总数。
路径(Path):在图中,路径是一系列相邻的节点,它们通过边相连。路径的长度可以通过经过的边数或权重来度量。
有向图(Directed Graph):也称为有向图,图中的边具有方向。在有向图中,从一个节点到另一个节点的边是单向的。
无向图(Undirected Graph):在无向图中,图中的边没有方向,可以双向移动。
环(Cycle):在图中,如果一条路径可以回到起始节点,形成一个闭合的环,那么该路径被称为环。
连通性(Connectivity):一个图或图中的一部分被称为连通的,如果从任何一个节点到另一个节点都存在路径。
度数(Degree):节点的度数是与该节点相连的边的数量。在有向图中,分为入度(In-Degree)和出度(Out-Degree)。
子图(Subgraph):一个图的子集,包括一些节点和连接这些节点的边。
稀疏图和稠密图:稀疏图是具有相对较少边的图,而稠密图具有相对较多的边。
图是一种非常通用的数据结构,它在许多领域中都有广泛的应用,包括网络分析、社交网络、路线规划、数据库系统、编译器设计、图像处理等。不同类型的图和图算法被用于不同的问题,如最短路径问题、网络流问题、最小生成树问题等。了解这些基本概念是理解和使用图的关键。

三、常见图算法
图算法是解决图数据结构中的各种问题的算法。以下是一些常见的图算法,以及它们的简要介绍和C#、Java的代码示例:

3.1 深度优先搜索(DFS):
算法介绍:DFS 用于遍历图,从一个起始节点开始,沿着一条路径尽可能深入,直到无法再继续。然后,回溯到上一个节点,继续深入其他路径,直到所有节点都被访问。
应用:查找连通组件、拓扑排序、解决迷宫问题等。

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

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

相关文章

re-captioning技术是什么

参考https://zhuanlan.zhihu.com/p/664192860 模型对图片进行caption操作时&#xff0c;输出的标题一般描述图片中的主体&#xff0c;而忽视了背景、常识关系等更为细节的描述。 图片比较重要的细节的描述应当包括&#xff1a; 物体存在的场景。如&#xff1a;在厨房的水槽&am…

Qt之条件变量QWaitCondition详解(从使用到原理分析全)

QWaitCondition内部实现结构图&#xff1a; 相关系列文章 C之Pimpl惯用法 目录 1.简介 2.示例 2.1.全局配置 2.2.生产者Producer 2.3.消费者Consumer 2.4.测试例子 3.原理分析 3.1.辅助函数CreateEvent 3.2.辅助函数WaitForSingleObject 3.3.QWaitConditionEvent …

阿里云服务器服务费怎么计算的?详细报价解析

2024年最新阿里云服务器租用费用优惠价格表&#xff0c;轻量2核2G3M带宽轻量服务器一年61元&#xff0c;折合5元1个月&#xff0c;新老用户同享99元一年服务器&#xff0c;2核4G5M服务器ECS优惠价199元一年&#xff0c;2核4G4M轻量服务器165元一年&#xff0c;2核4G服务器30元3…

001 - Hugo, 创建一个网站

001 - Hugo, 创建一个网站安装hugoWindows系统Macos Hugo博客搭建初始化博客主题安装配置博客各个页面开始创作创建 GitHub Page 仓库本地调试和预览发布内容 教程及鸣谢文字教程视频教程 001 - Hugo, 创建一个网站 这篇文章假设你已经&#xff1a; 了解基本的终端命令行知识&…

黑马鸿蒙教程学习1:Helloworld

今年打算粗略学习下鸿蒙开发&#xff0c;当作兴趣爱好&#xff0c;通过下华为那个鸿蒙开发认证&#xff0c; 发现黑马的课程不错&#xff0c;有视频和完整的代码和课件下载&#xff0c;装个devstudio就行了&#xff0c;建议32G内存。 今年的确是鸿蒙大爆发的一年呀&#xff0c;…

Win32汇编数组学习2

之前学习过win32汇编数组&#xff1b;还不熟悉&#xff1b;继续熟悉&#xff1b; 先做几个基本的对话框&#xff0c;有一个静态文本框&#xff1b; 定义数组之后&#xff0c;用 wsprintf 函数格式化&#xff0c;然后调用 SetDlgItemText 赋值给静态文本框&#xff1b; arr1 …

【力扣hot100】刷题笔记Day5

前言 回学校了&#xff0c;荒废了半天之后打算奋发图强猛猛刷题&#xff0c;找实习&#xff01;赚钱&#xff01;&#xff01; 560. 和为 K 的子数组 - 力扣&#xff08;LeetCode&#xff09; 前缀法 哈希表 这个题解解释比官方清晰&#xff0c;截个图方便看&#xff0c;另一…

OpenCV-42 直方图均匀化

目录 一、直方图均匀化原理 二、直方图均匀化在OpenCV中的运用 一、直方图均匀化原理 直方图均匀化是通过拉伸像素强度的分布范围&#xff0c;使得在0~255灰阶上的分布更加均匀&#xff0c;提高图像的对比度。达到改善图像主管视觉效果的目的。对比度较低的图像适合使用直方…

由于找不到MSVCP140.dll无法运行软件游戏,多种解决方法分享

电脑系统在运行过程中&#xff0c;当出现“由于找不到MSVCP140.dll”这一提示时&#xff0c;可能会引发一系列潜在的问题与影响。当电脑无法找到这个特定的dll文件时&#xff0c;意味着相关应用可能无法顺利加载并执行必要的组件&#xff0c;进而导致程序无法启动或运行过程中频…

【PCB】Allegro PCB 的模块复用操作

【PCB】Allegro PCB 的模块复用操作

51_蓝桥杯_led流水灯

一 原理图分析 二 三八译码器工作原理 三八译码器&#xff1a;3个输入控制8路互斥的低电平有效输出。 C B A 输出 0 0 0 Y0 0 0 1 Y1 0 1 0 Y2 0 1 1 Y3 1 0 0 Y4 1 0 1 Y5 1 1 0 Y6 1 1 1 Y7 三 锁存器工作原理 锁存器&#xff1a;当使…

Open CASCADE学习|布尔运算

目录 1、加法&#xff1a;BRepAlgoAPI_Fuse 2、减法&#xff1a;BRepAlgoAPI_Cut 3、交集&#xff1a;BRepAlgoAPI_Common 4、交线&#xff1a;BRepAlgoAPI_Section 1、加法&#xff1a;BRepAlgoAPI_Fuse #include <gp_Pnt.hxx>#include <BRepPrimAPI_MakeBox.hxx…

“我觉得我今年可能要随便找个人嫁了,下半辈子应该都不会再快乐了”

2月15日&#xff0c;“张颂文情商”的话题登上热搜&#xff0c;引发网友热议。 许多人对张颂文老师的情商表达了高度的赞扬和敬意&#xff0c;纷纷感叹&#xff1a;“张颂文老师真的是一个非常会安慰人的人&#xff01;” 在2月13日的一条微博中&#xff0c;张颂文分享了家里三…

【JavaEE】_HTTP请求首行

目录 1. URL 2. 方法 2.1 GET方法 2.2 POST方法 2.3 GET与POST的区别 2.4 低频使用方法 1. URL 在mysql JDBC中已经提到过URL的相关概念&#xff1a; 如需查看有关JDBC更多内容&#xff0c;原文链接如下&#xff1a; 【MySQL】_JDBC编程-CSDN博客 URL用于描述某个资源…

K8s进阶之路-安装部署K8s

参考&#xff1a;&#xff08;部署过程参考的下面红色字体文档链接就可以&#xff0c;步骤很详细&#xff0c;重点部分在下面做了标注&#xff09; 安装部署K8S集群文档&#xff1a; 使用kubeadm方式搭建K8S集群 GitBook 本机&#xff1a; master&#xff1a;10.0.0.13 maste…

[Angular 基础] - 视图封装 局部引用 父子组件中内容传递

[Angular 基础] - 视图封装 & 局部引用 & 父子组件中内容传递 之前的笔记&#xff1a; [Angular 基础] - Angular 渲染过程 & 组件的创建 [Angular 基础] - 数据绑定(databinding) [Angular 基础] - 指令(directives) 以上为静态页面&#xff0c;即不涉及到跨组…

模拟算法.

1.什么是模拟 在信息奥赛中,有一类问题是模拟一个游戏的对弈过程或者模拟一项任务的操作过程.比如乒乓球在比赛中模拟统计记分最终判断输赢的过程等等,这些问题通常很难通过建立数学模型用特定的算法来解决因为它没有一种固定的解法,需要深刻理解出题者对过程的解释一般只能采…

【sgCreateTableData】自定义小工具:敏捷开发→自动化生成表格列数据数组[基于el-table]

源码 <template><!-- 前往https://blog.csdn.net/qq_37860634/article/details/136141769 查看使用说明 --><div :class"$options.name"><div class"sg-head">表格数据生成工具</div><div class"sg-container&quo…

政安晨:【完全零基础】认知人工智能【机器学习】的【神经网络】 【超级简单】(一)

开个头 很多小伙伴们很想亲近人工智能与机器学习领域&#xff0c;然而这个领域里的核心理论、算法、工具给人感觉都太过“高冷”&#xff0c;让很多小伙伴们望而却步&#xff0c;导致一直无法入门。 如何捅破这层窗户纸&#xff1f; 让高冷的不再高冷&#xff0c;让神秘的不…

Windows环境部署nginx 文件服务器

文章目录 前言一、pandas是什么&#xff1f;二、使用步骤 1.引入库2.读入数据总结 前言 在Windows环境下使用nginx部署简单的文件服务器 一、版本 1. Windows 使用版本 2. nginx 使用版本 选择Mainline Version版本 二、nginx配置 1. 下载 https://nginx.org/en/download.…