概述
输入
每一行包含一个uid,遇到0时认为输入结束。
输入共包含N+1行,可认为是无序的。
输出
一个数字:去重后uid的数量M。
样例输入
12933
111111
59220
69433
59220
0
样例输出
4
数据范围
0<uid<2^63
对于30%的数据,0<N<100,000,0<M<100,000
对于100%的数据,0<N<1000,000,0<M<800,000
若使用string会存在超时的情况,一个字符是一个字节,占据空间更大
unsigned int 0~4294967295
int -2147483648~2147483647
unsigned long 0~4294967295
long -2147483648~2147483647
long long的最大值:9223372036854775807
long long的最小值:-9223372036854775808
unsigned long long的最大值:1844674407370955161
(long long占据64bit)
__int64的最大值:9223372036854775807
__int64的最小值:-9223372036854775808
unsigned __int64的最大值:18446744073709551615
代码如下:
#include <iostream>
#include <unordered_set>
#include <string>
#include <vector>
using namespace std;
int main() {
long long num, res = 0;
unordered_set<long long> dic;
while (cin >> num) {
if (num == 0) break;
//if an element with a value equivalent to k is found, or zero otherwise.
if (dic.count(num) == 0) {
res++;
dic.insert(num);
}
}
cout << res << endl;
return 0;
}
最后
以上就是激动柚子为你收集整理的string与long long的区别的全部内容,希望文章能够帮你解决string与long long的区别所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复