BOJ1620
BOJ 1620. ポケモンマスターです
質問する
コード#コード#
#include <iostream>
#include <vector>
#include <string>
#include <sstream>
using namespace std;
int num, low, high;
string temp;
int main(int argc, char const *argv[])
{
cin.tie(NULL);
ios::sync_with_stdio(false);
int n, m;
cin >> n >> m;
vector<pair<string, int> > v;
vector<string> v1;
for (int i = 1; i <= n; i++)
{
string pokemon;
cin >> pokemon;
v1.push_back(pokemon);
v.push_back(make_pair(pokemon, i));
}
sort(v.begin(), v.end());
for (int i = 1; i <= m; i++)
{
cin >> temp;
if (temp[0] >= '0' && temp[0] <= '9')
{
std::stringstream ssInt(temp);
ssInt >> num;
// num = stoi(temp);
cout << v1[num - 1] << '\n';
}
else
{
low = 0;
high = n - 1;
while (low <= high)
{
int mid = (low + high) / 2;
if (v[mid].first == temp)
{
cout << v[mid].second << '\n';
break;
}
else if (v[mid].first < temp)
{
low = mid + 1;
}
else
{
high = mid - 1;
}
}
}
}
return 0;
}
この探索の前にタイムアウトエラーが発生した.Nは10万です.
解決策として、二分探索で価格を見つけた.
そして、数字のみが入力されないようにv 1ベクトル(文字列値のみ含む)を別途作成し、直接出力します.
Reference
この問題について(BOJ1620), 我々は、より多くの情報をここで見つけました
https://velog.io/@aksel26/BOJ1620
テキストは自由に共有またはコピーできます。ただし、このドキュメントのURLは参考URLとして残しておいてください。
Collection and Share based on the CC Protocol
#include <iostream>
#include <vector>
#include <string>
#include <sstream>
using namespace std;
int num, low, high;
string temp;
int main(int argc, char const *argv[])
{
cin.tie(NULL);
ios::sync_with_stdio(false);
int n, m;
cin >> n >> m;
vector<pair<string, int> > v;
vector<string> v1;
for (int i = 1; i <= n; i++)
{
string pokemon;
cin >> pokemon;
v1.push_back(pokemon);
v.push_back(make_pair(pokemon, i));
}
sort(v.begin(), v.end());
for (int i = 1; i <= m; i++)
{
cin >> temp;
if (temp[0] >= '0' && temp[0] <= '9')
{
std::stringstream ssInt(temp);
ssInt >> num;
// num = stoi(temp);
cout << v1[num - 1] << '\n';
}
else
{
low = 0;
high = n - 1;
while (low <= high)
{
int mid = (low + high) / 2;
if (v[mid].first == temp)
{
cout << v[mid].second << '\n';
break;
}
else if (v[mid].first < temp)
{
low = mid + 1;
}
else
{
high = mid - 1;
}
}
}
}
return 0;
}
Reference
この問題について(BOJ1620), 我々は、より多くの情報をここで見つけました https://velog.io/@aksel26/BOJ1620テキストは自由に共有またはコピーできます。ただし、このドキュメントのURLは参考URLとして残しておいてください。
Collection and Share based on the CC Protocol