欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++求兩數(shù)之和并返回下標(biāo)詳解

 更新時(shí)間:2021年08月19日 09:23:22   作者:久病成良醫(yī)  
這篇文章主要介紹了C++求兩數(shù)之和并返回下標(biāo)題目的代碼詳解,本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下

給定一個(gè)整數(shù)數(shù)組 nums 和一個(gè)整數(shù)目標(biāo)值 target,請(qǐng)你在該數(shù)組中找出 和為目標(biāo)值 target 的那 兩個(gè) 整數(shù),并返回它們的數(shù)組下標(biāo)。

你可以假設(shè)每種輸入只會(huì)對(duì)應(yīng)一個(gè)答案。但是,數(shù)組中同一個(gè)元素在答案里不能重復(fù)出現(xiàn)。

你可以按任意順序返回答案。

示例:

輸入:nums = [2,7,11,15], target = 9

輸出:[0,1]

解釋:因?yàn)?nums[0] + nums[1] == 9 ,返回 [0, 1] 。

ACM模式

#include <iostream>
#include <vector>
#include <unordered_map>
using namespace std;
int main(){
	vector<int> nums{ 2, 7, 11, 13 }; //原數(shù)組
	vector<int> vec; //存放結(jié)果
	int target = 18;
	unordered_map<int, int> ump;
	for (int i = 0; i < nums.size(); ++i){
		auto it = ump.find(target - nums[i]);
		if (it != ump.end()){
			vec.push_back(it->second); //將值插入vec中
			vec.push_back(i);
		}
		ump[nums[i]] = i; //鍵值對(duì)的存入
	}
	for (int i = 0; i < vec.size(); ++i){
		cout << vec[i] << endl;
	}
}

核心代碼模式

方法一:

class Solution
{
public:
	vector<int> TwoSum(vector<int>&nums, int target)
	{
		int n = nums.size;
		for (int i = 0; i < n - 1; ++i)
		{
			for (int j = i + 1; j < n; ++j)
			{
				if (nums[i] + nums[j] == target)   
					return{ i, j };
			}
		}
		return{};  //空的{}表示一個(gè)空的vector<int>
	}
};

使用vector需要添加頭文件

#include <vector> 
using namespace std;

創(chuàng)建vector

vector<int> nums; //不指定長(zhǎng)度:
vector<int> nums(n); //指定長(zhǎng)度為n:
vector<int> nums(10,1);//定義具有10個(gè)整型元素的向量,且給出的每個(gè)元素初值為1
                       //nums后面是括號(hào)()不是大括號(hào){}

添加元素

直接從數(shù)組末端添加:

nums.push_back(1);

直接賦值給第i個(gè)位置:

nums[i] = 1;

刪除元素

直接將數(shù)組長(zhǎng)度減小,某種方式上刪掉了后面i個(gè):

nums.resize(nums.size-i);

刪掉最后一個(gè)元素:

nums.pop_back();

其他

nums.size(); //獲得長(zhǎng)度
sort(nums.begin(),nums.end()); //排序(O(nlogn))
reverse(nums.begin(), nums.end()); //翻轉(zhuǎn)
合并兩個(gè)vector:合并nums1和nums2,并將合并后的數(shù)組賦值給nums
vector<int> nums1(m),nums2(n);
vector<int> nums;
nums.resize(m+n); 
merge(nums1.begin(), nums1.end(),nums2.begin(),nums2.end(),nums);

方法二:

class Solution {
public:
    vector<int> twoSum(vector<int>& nums, int target) {
        unordered_map<int,int>hashtable;    // 建立哈希表
        for(int i=0;i<nums.size();++i){     //nums.size后面要帶括號(hào)()
        // for(auto i:nums)  錯(cuò)誤,因?yàn)橹挥兄纈的類型才可以用auto
            auto it=hashtable.find(target-nums[i]); //返回類型是iterator迭代器
            if(it!=hashtable.end()){     // 查找it是否在hashtable里
                return{it->second,i};   //first是鍵(key),second是值(value)
                                        //hashtable[nums[i]]=i,first就是nums[i],second就是i
            }
            hashtable[nums[i]]=i;   //存入鍵值對(duì)。 hashtable(nums[i])=i;錯(cuò)誤,是[]不是()
        }
        return{};
    }
};

在這里插入圖片描述

auto的使用

C++11中引入的auto主要有兩種用途:自動(dòng)類型推斷和返回值占位。

1.自動(dòng)類型推斷

auto a;                 錯(cuò)誤,沒有初始化表達(dá)式,無法推斷出a的類型
auto int a = 10;        錯(cuò)誤,auto臨時(shí)變量的語義在C++11中已不存在, 這是舊標(biāo)準(zhǔn)的用法。
auto a = 10;
auto c = 'A';
auto s("hello");

2.返回值占位

auto v = compose(2, 3.14);    v 的類型是 double

unordered_map

unordered_map的頭文件

#include <unordered_map>

創(chuàng)建unordered_map容器:

unordered_map<string,string>umap;
//創(chuàng)建好了一個(gè)可存儲(chǔ) <string,string> 類型鍵值對(duì)的 unordered_map 容器
unordered_map<int,int>umap;
//第一個(gè)int是鍵,第二個(gè)int是值

unordered_map容器的成員方法

begin()	//返回指向容器中第一個(gè)鍵值對(duì)的正向迭代器。
end() 	//返回指向容器中最后一個(gè)鍵值對(duì)之后位置的正向迭代器。
find(key)	//查找以 key 為鍵的鍵值對(duì),如果找到,則返回一個(gè)指向該鍵值對(duì)的正向迭代器;反之,則返回一個(gè)指向容器中最后一個(gè)鍵值對(duì)之后位置的迭代器(如果 end() 方法返回的迭代器)。
cbegin()和 begin() //功能相同,只不過在其基礎(chǔ)上增加了 const 屬性,即該方法返回的迭代器不能用于修改容器內(nèi)存儲(chǔ)的鍵值對(duì)。
cend()和 end() //功能相同,只不過在其基礎(chǔ)上,增加了 const 屬性,即該方法返回的迭代器不能用于修改容器內(nèi)存儲(chǔ)的鍵值對(duì)。
empty()	//若容器為空,則返回 true;否則 false。
size()	//返回當(dāng)前容器中存有鍵值對(duì)的個(gè)數(shù)。
max_size()	//返回容器所能容納鍵值對(duì)的最大個(gè)數(shù),不同的操作系統(tǒng),其返回值亦不相同。
operator[key]	//該模板類中重載了 [] 運(yùn)算符,其功能是可以向訪問數(shù)組中元素那樣,只要給定某個(gè)鍵值對(duì)的鍵 key,就可以獲取該鍵對(duì)應(yīng)的值。注意,如果當(dāng)前容器中沒有以 key 為鍵的鍵值對(duì),則其會(huì)使用該鍵向當(dāng)前容器中插入一個(gè)新鍵值對(duì)。
at(key)	//返回容器中存儲(chǔ)的鍵 key 對(duì)應(yīng)的值,如果 key 不存在,則會(huì)拋出 out_of_range 異常。 
count(key)	//在容器中查找以 key 鍵的鍵值對(duì)的個(gè)數(shù)。
equal_range(key)	//返回一個(gè) pair 對(duì)象,其包含 2 個(gè)迭代器,用于表明當(dāng)前容器中鍵為 key 的鍵值對(duì)所在的范圍。
emplace()	//向容器中添加新鍵值對(duì),效率比 insert() 方法高。
emplace_hint()	//向容器中添加新鍵值對(duì),效率比 insert() 方法高。
insert() 	//向容器中添加新鍵值對(duì)。
erase()	//刪除指定鍵值對(duì)。
clear() 	//清空容器,即刪除容器中存儲(chǔ)的所有鍵值對(duì)。
swap()	//交換 2 個(gè) unordered_map 容器存儲(chǔ)的鍵值對(duì),前提是必須保證這 2 個(gè)容器的類型完全相等。
bucket_count()	//返回當(dāng)前容器底層存儲(chǔ)鍵值對(duì)時(shí),使用桶(一個(gè)線性鏈表代表一個(gè)桶)的數(shù)量。
max_bucket_count()	//返回當(dāng)前系統(tǒng)中,unordered_map 容器底層最多可以使用多少桶。
bucket_size(n)	//返回第 n 個(gè)桶中存儲(chǔ)鍵值對(duì)的數(shù)量。
bucket(key)	//返回以 key 為鍵的鍵值對(duì)所在桶的編號(hào)。
load_factor()	//返回 unordered_map 容器中當(dāng)前的負(fù)載因子。負(fù)載因子,指的是的當(dāng)前容器中存儲(chǔ)鍵值對(duì)的數(shù)量(size())和使用桶數(shù)(bucket_count())的比值,即 load_factor() = size() / bucket_count()。
max_load_factor()	//返回或者設(shè)置當(dāng)前 unordered_map 容器的負(fù)載因子。
rehash(n)	//將當(dāng)前容器底層使用桶的數(shù)量設(shè)置為 n。
reserve()	//將存儲(chǔ)桶的數(shù)量(也就是 bucket_count() 方法的返回值)設(shè)置為至少容納count個(gè)元(不超過最大負(fù)載因子)所需的數(shù)量,并重新整理容器。
hash_function()	//返回當(dāng)前容器使用的哈希函數(shù)對(duì)象。

查找元素是否存在

若有unordered_map <int, int> mp;查找x是否在map中

方法1:  若存在   mp.find(x) != mp.end()
方法2:  若存在   mp.count(x) != 0

c++中當(dāng)定義類對(duì)象是指針對(duì)象時(shí)候,就需要用到 -> 指向類中的成員;
當(dāng)定義一般對(duì)象時(shí)候時(shí)就需要用到 “.” 指向類中的成員。
例如:

class A
{  
    public play();
}

如果定義如下:

A *p則使用:p->play(); 左邊是結(jié)構(gòu)指針。

A p 則使用:p.paly(); 左邊是結(jié)構(gòu)變量。

總結(jié):

箭頭(->):左邊必須為指針;

點(diǎn)號(hào)(.):左邊必須為實(shí)體。

本篇文章就到這里了,希望能給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!

相關(guān)文章

  • C++ Opengl圖形顏色功能附源碼下載

    C++ Opengl圖形顏色功能附源碼下載

    這篇文章主要介紹了C++ Opengl圖形顏色功能附源碼下載,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-11-11
  • C語言版飛機(jī)大戰(zhàn)游戲

    C語言版飛機(jī)大戰(zhàn)游戲

    這篇文章主要為大家詳細(xì)介紹了C語言版飛機(jī)大戰(zhàn)游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • C++利用stringstream進(jìn)行數(shù)據(jù)類型轉(zhuǎn)換實(shí)例

    C++利用stringstream進(jìn)行數(shù)據(jù)類型轉(zhuǎn)換實(shí)例

    這篇文章主要介紹了C++利用stringstream進(jìn)行數(shù)據(jù)類型轉(zhuǎn)換的方法,實(shí)例分析了使用stringstream進(jìn)行string轉(zhuǎn)int的操作技巧,需要的朋友可以參考下
    2015-01-01
  • c++中處理相關(guān)數(shù)學(xué)函數(shù)

    c++中處理相關(guān)數(shù)學(xué)函數(shù)

    數(shù)學(xué)庫函數(shù)聲明在 math.h 中,主要有:
    2013-04-04
  • QT基于TCP實(shí)現(xiàn)文件傳輸系統(tǒng)

    QT基于TCP實(shí)現(xiàn)文件傳輸系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了QT基于TCP實(shí)現(xiàn)文件傳輸系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • C++最優(yōu)二叉樹哈夫曼樹算法解析

    C++最優(yōu)二叉樹哈夫曼樹算法解析

    這篇文章主要介紹了C++最優(yōu)二叉樹哈夫曼樹算法解析,哈夫曼樹又稱最優(yōu)二叉樹,是一種帶權(quán)路徑長(zhǎng)度最短的二叉樹,所謂樹的帶權(quán)路徑長(zhǎng)度,就是樹中所有的葉結(jié)點(diǎn)的權(quán)值乘上其到根結(jié)點(diǎn)的路徑長(zhǎng)度,需要的朋友可以參考下
    2023-08-08
  • VS2019中QT連接及使用的方法步驟

    VS2019中QT連接及使用的方法步驟

    這篇文章主要介紹了VS2019中QT連接及使用的方法步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-08-08
  • C/C++ Zlib庫封裝MyZip壓縮類的詳細(xì)過程

    C/C++ Zlib庫封裝MyZip壓縮類的詳細(xì)過程

    在軟件開發(fā)中,文件的壓縮和解壓縮是一項(xiàng)常見的任務(wù),而ZIP是一種被廣泛應(yīng)用的壓縮格式,本文將聚焦于一個(gè)簡(jiǎn)化的C++實(shí)現(xiàn),通過分析代碼,我們將深入了解其設(shè)計(jì)和實(shí)現(xiàn)細(xì)節(jié),感興趣的朋友一起看看吧
    2023-11-11
  • 解析C++編程中的繼承方面的運(yùn)用

    解析C++編程中的繼承方面的運(yùn)用

    這篇文章主要介紹了解析C++編程中的繼承方面的運(yùn)用,是C++入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-09-09
  • C++中vector的常用接口詳析說明

    C++中vector的常用接口詳析說明

    vector類我們可以將其看作是一個(gè)能夠動(dòng)態(tài)擴(kuò)容的數(shù)組,下面這篇文章主要給大家介紹了關(guān)于?C++?vector常用接口的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-08-08

最新評(píng)論