C向C++的一个过渡

news2024/12/23 3:16:36

思维导图

 输入输出,以及基础头文件

在c语言中我们常用scanf("%d",&n);和printf("%d\n",n);来输出一些变量和常量,在C++中我们可以用cin;和cout;来表示输入输出。

在C语言中输入输出有头文件,在C++也有头文件,只不过C++的头文件有一点奇怪,他首先是要包括一个输入输出流(即iostream,i表示cin中的i.o就是表示输出也就是cout,这个stream在英文中表示的是是水流的意思,在计算机的眼中,信息是像水一样流进计算机的,处理玩的信息是像水一样留出计算机的),所以这个头文件就叫左iostream,然后这个还要用一个using namespace std。这个是内存申请一个空间,并且将stdio.h中的函数放进去(虽然stdio.h的函数很少),哪里可以看到这个stdio.h呢,就是在namespace的后面std,这个就是stdio.h。

这是对数字和特殊字符的输出:

#include<iostream>
using namespace std;
int main()
{
   int n=1;//下面这三种都是等价的
   printf("%d %d\n",n,n+1);
   cout<<n<<" "<<n+1<<endl;
   cout<<n<<" "<< n+1<<"\n";
}

接下来就是有关字符串

数值

最大值:0x3f3f3f3f(4个f,3个0)或者0x7fffffff(这里一共7个f)这两玩意都是表示最大值的意思,数量级是 10^9 .

#define INF 0x3f3f3f3f或者const int INF = 0x3f3f3f3f来使自己定义的变量inf(所以以后看到这个不要慌,这个就是表示最大值的意思)。

函数

s1.substr()函数

使用的方法就是:设置一个字符串s1,然后将这个字符串用‘.’连接起来,括号里面有两个变量,第一个变量需要开始的位置(往往是指下标,所以就需要减一),第二个变量是你需要的长度。用一个新的字符串来存储s1中你所需要的的这一段字符.
 

#include<bits/stdc++.h>
using namespace std;
int main()
{
	string s1;
	cin>>s1;
    string s2;
    s2=s1.substr(1,4);//从下标为0的地方开始,直到长度为4
    cout<<s2<<endl;
	return 0;
}

 

s1.find(ch)函数

这个是在字符串s1里面找到一个和ch一样的字符,并且返回其位置(注意这个是返回下标,所以是长度减1)
 

#include<bits/stdc++.h>
using namespace std;
int main()
{
	string s1,s2;
	char ch;
	cin>>s1;
	cin>>s2;
	cin>>ch;
	int len1,len2;
	len1=s1.find(s2);
	len2=s1.find(ch);
    cout << len1 << endl;
    cout << len2 << endl;
	return 0;
}

sort函数

sort函数中含有三个变量,第一个和第二个是需要排序的范围(就是数组名加上数字),然后第三个就是决定升序或者降序的,如果不进行填写就是代表着升序。头文件在include<algorithm>,这个英文单词也是算法的意思

#include<iostream>
#include<string.h>
#include<algorithm>
using namespace std;
int main()
{
	int a[10];
	for(int i=1;i<=5;i++)
	cin>>a[i];
	sort(a+1,a+5);
	for(int i=1;i<=5;i++)
	cout<<a[i]<<"  ";
	return 0;
}

降序就在最后面加上一个greater<int>() 
升序就是在最后加一个less<int>() (或者可以什么都不写)

sort(a, a + n, greater<int>());//降序排列
sort(a, a + n, less<int>());//升序排列

接下来就是有关如何用sort函数来编写对结构体的排序:
主要就是对结构体其中的某个元素进行排序,然后将结构体全部元素都进行一个排序,所以这里最关键的就是对“标准”的定义(大白话就是对哪一个元素排序)。
首先我们就需要构造一个结构体

struct node
{
    int x,y,t;
} q[N];

然后书写规则(这里就需要书写一个bool类型的函数)

bool cmp(node x,node y)
{
    return x.t<y.t;//这个就是升序的标准
}

然后再将这个标准放在sort函数中的最后一位

sort(q,q+m,cmp);

 find函数

头文件是include<algorithm>
这个头文件包含了很多函数,所以建议大家先去看看这个里面所有函数,以便在书写变量和函数名重合。函数格式:InputIterator find (InputIterator first, InputIterator last, const T& val);

first 和 last 为输入迭代器(迭代其就相当于一个是勺子,可以向一碗汤中送汤,也可以从汤中捞汤),[first, last) 用于指定该函数的查找范围;val 为要查找的目标元素。
另外,该函数会返回一个输入迭代器,当 find() 函数查找成功时,其指向的是在 [first, last) 区域内查找到的第一个目标元素;如果查找失败,则该迭代器的指向和 last 相同。
具体的时使用代码如下(由于还没又进一部学习vector,所以后面的我也看不懂)
 

#include <iostream>     // std::cout
#include <algorithm>    // std::find
#include <vector>       // std::vector
using namespace std;
int main() {
    //find() 函数作用于普通数组
    char stl[] ="http://c.biancheng.net/stl/";
    //调用 find() 查找第一个字符 'c'
    char * p = find(stl, stl + strlen(stl), 'c');
    //判断是否查找成功
    if (p != stl + strlen(stl)) {
        cout << p << endl;
    }
    //find() 函数作用于容器
    std::vector<int> myvector{ 10,20,30,40,50 };
    std::vector<int>::iterator it;
    it = find(myvector.begin(), myvector.end(), 30);
    if (it != myvector.end())
        cout << "查找成功:" << *it;
    else
        cout << "查找失败";
    return 0;
}

strstr函数

map函数、

这个函数首先是底一个变量就是它的·类型这个类型就是

队列等头文件

1.这里要用到一个优先队列(stl),其本质就是用一个数组模拟的一个完全二叉树。
2.功能:拿出优先级最大的元素,这个优先级可以自己定义。
3.这个包括在头文件#include<queue>之中。
4.定义方式:priority_queue<int> que   尖括号说明里面存放的数是整型(这样定义就是大顶堆 值越大优先级越高)
5.关于优先队列的几种操作:1.que.size()  得到这个队列的元素数量
                                              2.que.push(x)  插入
                                              3.que.pop()  删除优先级最高的元素
                                              4.que.top()访问优先级最高的元素(访问堆顶元素)
                                              5.que.empty()判断堆是否为空
插入删除的时间复杂空间度都是为对数级,访问堆顶元素的时间复杂度为常数级别。

接下俩是堆优先队列的一些基础操作

#include<iostream>
#include<queue>
#include<algorithm>
using namespace std;
int main()
{
	priority_queue<int> que;
	que.push(7);
	que.push(1);
	que.push(12);
	printf("nmber:");
	cout<<que.size()<<endl;
	while(!que.empty())
	{
		cout<<que.top()<<endl;
		que.pop();
	}
	cout<<endl;
	return 0;
}

输出数据如下(这样就可以使用堆排序)

  对于我们自定义

#include<iostream>
#include<queue>
#include<algorithm>
using namespace std;
struct node
{
	int x,y;
	bool operator< (const node &b) const{//运算符重新定义,注意这个运算符只能定义小于号
		return this->x>b.x;//从大到小
	}
};

int main()
{
	priority_queue<node> que;
	que.push((node){5,2});
	que.push((node){2,4});
	while(!que.empty())
	{
		cout<<que.top().x<<endl;
		que.pop();
	}
	return 0;
}

 输出结果:

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

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

相关文章

解放人力,提升品质:码垛输送机的工业应用与价值

在现代工业生产中&#xff0c;码垛输送机已成为许多企业自动化生产线上的关键设备。它不仅可以提高生产效率&#xff0c;降低人力成本&#xff0c;还能确保产品质量&#xff0c;并为企业带来许多其他方面的实际好处。 1. 提高生产效率&#xff1a; 快速码垛&#xff1a;码垛输…

蓝桥杯练习题——dp

五部曲&#xff08;代码随想录&#xff09; 1.确定 dp 数组以及下标含义 2.确定递推公式 3.确定 dp 数组初始化 4.确定遍历顺序 5.debug 入门题 1.斐波那契数 思路 1.f[i]&#xff1a;第 i 个数的值 2.f[i] f[i - 1] f[i - 2] 3.f[0] 0, f[1] 1 4.顺序遍历 5.记得特判 …

基于springboot+vue的医院药品管理系统

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、阿里云专家博主、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战&#xff0c;欢迎高校老师\讲师\同行交流合作 ​主要内容&#xff1a;毕业设计(Javaweb项目|小程序|Pyt…

STM32CubeIDE基础学习-新建STM32CubeIDE基础工程

STM32CubeIDE基础学习-新建STM32CubeIDE基础工程 前言 有开发过程序的朋友都清楚&#xff0c;后面开发是不需要再新建工程的&#xff0c;一般都是在初学时或者有特殊需要的时候才需要新建项目工程的。 后面开发都是可以在这种已有的工程上添加相关功能就行&#xff0c;只要前…

Linux系统部署Discuz论坛并发布至公网随时随地可远程访问

目录 ​编辑 前言 1.安装基础环境 2.一键部署Discuz 3.安装cpolar工具 4.配置域名访问Discuz 5.固定域名公网地址 6.配置Discuz论坛 结语 作者简介&#xff1a; 懒大王敲代码&#xff0c;计算机专业应届生 今天给大家聊聊Linux系统部署Discuz论坛并发布至公网随时随地…

Qt+FFmpeg+opengl从零制作视频播放器-1.项目介绍

1.简介 学习音视频开发&#xff0c;首先从做一款播放器开始是比较合理的&#xff0c;每一章节&#xff0c;我都会将源码贴在最后&#xff0c;此专栏你将学习到以下内容&#xff1a; 1&#xff09;音视频的解封装、解码&#xff1b; 2&#xff09;Qtopengl如何渲染视频&#…

matlab 提取分割位于多边形区域边缘内部或边缘上的点

[in,on] = inpolygon(xq,yq,xv,yv) xv 和 yv 为定义的多边形区域的,如xv = [1 4 4 1 1 ];yv = [1 1 4 4 1 ];注意最后一个数字与第一个重复,保证多边形闭合; xq 和 yq 为待查询的点in:在多边形内部和边缘的点序号on:仅在多边形边缘的点序号 提取分割方法: matrix=[xq yq…

Hystrix的一些了解

Hystrix如何实现容错 Hystrix是一个延迟和容错库&#xff0c;旨在隔离远程系统&#xff0c;服务和第三方库的访问点&#xff0c;当出现故障是不可避 免的故障时&#xff0c;停止级联故障并在复杂的分布式系统中实现弹性。 通常对于使用微服务架构开发的系统&#xff0c;涉及到…

12. Nginx进阶-Location

简介 Nginx的三大区块 在Nginx中主要配置包括三个区块&#xff0c;结构如下&#xff1a; http { #协议级别include /etc/nginx/mime.types;default_type application/octet-stream;log_format main $remote_addr - $remote_user [$time_local] "$r…

13-Java代理模式 ( Proxy Pattern )

Java代理模式 摘要实现范例 代理模式&#xff08;Proxy Pattern&#xff09;使用一个类代表另一个类的功能 代理模式创建具有现有对象的对象&#xff0c;以便向外界提供功能接口 代理模式属于结构型模式 摘要 1. 意图 为其他对象提供一种代理以控制对这个对象的访问2. 主…

游戏引擎用什么语言开发上层应用

现在主流的游戏引擎包括&#xff1a; 1、Unity3D&#xff0c;C#语言&#xff0c;优点在于支持几乎所有平台 丹麦创立的一家公司&#xff0c;现已被微软收购。在中国市场占有率最高&#xff0c;也是社群很强大&#xff0c;一般解决方案也能在网上找到&#xff0c;教程丰富。物理…

springboot项目单纯使用nacos注册中心功能

Spring Boot 项目完全可以单独使用 Nacos 作为注册中心。Nacos 是一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。它支持服务的注册与发现&#xff0c;能够与 Spring Boot 应用无缝集成&#xff0c;为微服务架构提供了强大的支持。 在使用 Nacos 作为注册中…

eclipse搭建java web项目

准备条件 eclipsejdk1.8 &#xff08;配置jdk环境&#xff09;apache-tomcat-8.5.97&#xff08;记住安装位置&#xff09; 一 点击完成 开始创建javaweb项目 import java.io.IOException; import java.io.PrintWriter;import javax.servlet.ServletException; import javax.s…

java VR全景商城 saas商城 b2b2c商城 o2o商城 积分商城 秒杀商城 拼团商城 分销商城 短视频商城 小程序商城搭建

1. 涉及平台 平台管理、商家端&#xff08;PC端、手机端&#xff09;、买家平台&#xff08;H5/公众号、小程序、APP端&#xff08;IOS/Android&#xff09;、微服务平台&#xff08;业务服务&#xff09; 2. 核心架构 Spring Cloud、Spring Boot、Mybatis、Redis 3. 前端框架…

3.1_2024ctf青少年比赛部分web题

php后门 根据x-powered-by知道php的版本 该版本存在漏洞&#xff1a; PHP 8.1.0-dev 开发版本后门 根据报错信息&#xff0c;进行提示&#xff0c;前 GET / HTTP/1.1 Host: challenge.qsnctf.com:31639 User-Agentt:12345678system(cat /flag);var_dump(2*3);zerodium12345678…

二维码门楼牌管理系统技术服务:安装要求详解

文章目录 前言一、安装要求二、系统功能与应用三、总结与展望 前言 在信息化时代的浪潮下&#xff0c;二维码技术的应用已经深入到了我们生活的方方面面。其中&#xff0c;二维码门楼牌管理系统的出现&#xff0c;不仅提高了社区管理的效率&#xff0c;还为居民带来了极大的便…

tomcat优化、nginx +tomcat 部署 (三)

在目前流行的互联网架构中&#xff0c;Tomcat在目前的网络编程中是举足轻重的&#xff0c;由于Tomcat的运行依赖于JVM&#xff0c;从虚拟机的角度把Tomcat的调整分为外部环境调优 JVM 和 Tomcat 自身调优两部分 Tomcat 是一个流行的开源 Java 服务器&#xff0c;用于托管 Java …

Web前端---表格和表单

1.表格概述 表格标记&#xff1a;<table></table> 表格标题标记&#xff1a;<caption></caption> 表头&#xff1a;<th></th>------heading 行标记&#xff1a;<tr></tr>-----r是row 列标记&#xff1a;<td></t…

javaWebssh水利综合信息管理系统myeclipse开发mysql数据库MVC模式java编程计算机网页设计

一、源码特点 java ssh水利综合信息管理系统是一套完善的web设计系统&#xff08;系统采用ssh框架进行设计开发&#xff09;&#xff0c;对理解JSP java编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模式开发。开发环境为TOMCA…

【Python】OpenCV-使用ResNet50进行图像分类

使用ResNet50进行图像分类 如何使用ResNet50模型对图像进行分类。 import os import cv2 import numpy as np from tensorflow.keras.applications.resnet50 import ResNet50, preprocess_input, decode_predictions from tensorflow.keras.preprocessing import image# 设置…