C++求兩數(shù)之和并返回下標(biāo)詳解
給定一個整數(shù)數(shù)組 nums 和一個整數(shù)目標(biāo)值 target,請你在該數(shù)組中找出 和為目標(biāo)值 target 的那 兩個 整數(shù),并返回它們的數(shù)組下標(biāo)。
你可以假設(shè)每種輸入只會對應(yīng)一個答案。但是,數(shù)組中同一個元素在答案里不能重復(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; //鍵值對的存入
}
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{}; //空的{}表示一個空的vector<int>
}
};
使用vector需要添加頭文件
#include <vector> using namespace std;
創(chuàng)建vector
vector<int> nums; //不指定長度:
vector<int> nums(n); //指定長度為n:
vector<int> nums(10,1);//定義具有10個整型元素的向量,且給出的每個元素初值為1
//nums后面是括號()不是大括號{}
添加元素
直接從數(shù)組末端添加:
nums.push_back(1);
直接賦值給第i個位置:
nums[i] = 1;
刪除元素
直接將數(shù)組長度減小,某種方式上刪掉了后面i個:
nums.resize(nums.size-i);
刪掉最后一個元素:
nums.pop_back();
其他
nums.size(); //獲得長度 sort(nums.begin(),nums.end()); //排序(O(nlogn)) reverse(nums.begin(), nums.end()); //翻轉(zhuǎn)
合并兩個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后面要帶括號()
// for(auto i:nums) 錯誤,因?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; //存入鍵值對。 hashtable(nums[i])=i;錯誤,是[]不是()
}
return{};
}
};

auto的使用
C++11中引入的auto主要有兩種用途:自動類型推斷和返回值占位。
1.自動類型推斷
auto a; 錯誤,沒有初始化表達(dá)式,無法推斷出a的類型
auto int a = 10; 錯誤,auto臨時變量的語義在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)建好了一個可存儲 <string,string> 類型鍵值對的 unordered_map 容器 unordered_map<int,int>umap; //第一個int是鍵,第二個int是值
unordered_map容器的成員方法
begin() //返回指向容器中第一個鍵值對的正向迭代器。 end() //返回指向容器中最后一個鍵值對之后位置的正向迭代器。 find(key) //查找以 key 為鍵的鍵值對,如果找到,則返回一個指向該鍵值對的正向迭代器;反之,則返回一個指向容器中最后一個鍵值對之后位置的迭代器(如果 end() 方法返回的迭代器)。 cbegin()和 begin() //功能相同,只不過在其基礎(chǔ)上增加了 const 屬性,即該方法返回的迭代器不能用于修改容器內(nèi)存儲的鍵值對。 cend()和 end() //功能相同,只不過在其基礎(chǔ)上,增加了 const 屬性,即該方法返回的迭代器不能用于修改容器內(nèi)存儲的鍵值對。 empty() //若容器為空,則返回 true;否則 false。 size() //返回當(dāng)前容器中存有鍵值對的個數(shù)。 max_size() //返回容器所能容納鍵值對的最大個數(shù),不同的操作系統(tǒng),其返回值亦不相同。 operator[key] //該模板類中重載了 [] 運(yùn)算符,其功能是可以向訪問數(shù)組中元素那樣,只要給定某個鍵值對的鍵 key,就可以獲取該鍵對應(yīng)的值。注意,如果當(dāng)前容器中沒有以 key 為鍵的鍵值對,則其會使用該鍵向當(dāng)前容器中插入一個新鍵值對。 at(key) //返回容器中存儲的鍵 key 對應(yīng)的值,如果 key 不存在,則會拋出 out_of_range 異常。 count(key) //在容器中查找以 key 鍵的鍵值對的個數(shù)。 equal_range(key) //返回一個 pair 對象,其包含 2 個迭代器,用于表明當(dāng)前容器中鍵為 key 的鍵值對所在的范圍。 emplace() //向容器中添加新鍵值對,效率比 insert() 方法高。 emplace_hint() //向容器中添加新鍵值對,效率比 insert() 方法高。 insert() //向容器中添加新鍵值對。 erase() //刪除指定鍵值對。 clear() //清空容器,即刪除容器中存儲的所有鍵值對。 swap() //交換 2 個 unordered_map 容器存儲的鍵值對,前提是必須保證這 2 個容器的類型完全相等。 bucket_count() //返回當(dāng)前容器底層存儲鍵值對時,使用桶(一個線性鏈表代表一個桶)的數(shù)量。 max_bucket_count() //返回當(dāng)前系統(tǒng)中,unordered_map 容器底層最多可以使用多少桶。 bucket_size(n) //返回第 n 個桶中存儲鍵值對的數(shù)量。 bucket(key) //返回以 key 為鍵的鍵值對所在桶的編號。 load_factor() //返回 unordered_map 容器中當(dāng)前的負(fù)載因子。負(fù)載因子,指的是的當(dāng)前容器中存儲鍵值對的數(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() //將存儲桶的數(shù)量(也就是 bucket_count() 方法的返回值)設(shè)置為至少容納count個元(不超過最大負(fù)載因子)所需的數(shù)量,并重新整理容器。 hash_function() //返回當(dāng)前容器使用的哈希函數(shù)對象。
查找元素是否存在
若有unordered_map <int, int> mp;查找x是否在map中
方法1: 若存在 mp.find(x) != mp.end() 方法2: 若存在 mp.count(x) != 0
類
c++中當(dāng)定義類對象是指針對象時候,就需要用到 -> 指向類中的成員;
當(dāng)定義一般對象時候時就需要用到 “.” 指向類中的成員。
例如:
class A
{
public play();
}
如果定義如下:
A *p則使用:p->play(); 左邊是結(jié)構(gòu)指針。
A p 則使用:p.paly(); 左邊是結(jié)構(gòu)變量。
總結(jié):
箭頭(->):左邊必須為指針;
點(diǎn)號(.):左邊必須為實(shí)體。
本篇文章就到這里了,希望能給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
關(guān)于C++中數(shù)據(jù)16進(jìn)制輸出的方法
本文主要介紹了關(guān)于C++中數(shù)據(jù)16進(jìn)制輸出的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-03-03
淺談C++虛重載操作符 virtual operator= 的使用方法
下面小編就為大家?guī)硪黄獪\談C++虛重載操作符 virtual operator= 的使用方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-01-01
C++學(xué)習(xí)貝葉斯分類器實(shí)現(xiàn)手寫數(shù)字識別示例解析
這篇文章主要介紹了在C++學(xué)習(xí)中如何采用貝葉斯分類器來實(shí)現(xiàn)手寫數(shù)字識別的示例及解析有需要的朋友可以借鑒參考下,希望能夠有所幫助2021-10-10
Qt使用QSoundEffect類實(shí)現(xiàn)播放音效或音樂
這篇文章主要為大家詳細(xì)介紹了Qt如何使用QSoundEffect類實(shí)現(xiàn)播放音效或音樂功能,文中的示例代碼講解詳細(xì),有需要的小伙伴可以參考一下2024-12-12

