istringstream是一个比较有用的c++的输入输出控制类。
C++引入了ostringstream、istringstream、stringstream这三个类,要使用他们创建对象就必须包含这个头文件。
istringstream类用于执行C++风格的串流的输入操作。
ostringstream类用于执行C风格的串流的输出操作。
strstream类同时可以支持C风格的串流的输入输出操作。
istringstream的构造函数原形如下:
istringstream::istringstream(string str);
它的作用是从string对象str中读取字符。
#include<iostream>
#include<sstream> //istringstream 必须包含这个头文件
#include<string>
using namespace std;
int main()
{
string str="i an a boy";
istringstream is(str);
string s;
while(is>>s)
{
cout<<s<<endl;
}
}
输出是:
i
am
a
boy
Maximum GCD UVA - 11827
Given the N integers, you have to find the maximum GCD (greatest common divisor) of every possible
pair of these integers.
Input
The first line of input is an integer N (1 < N < 100) that determines the number of test cases.
The following N lines are the N test cases. Each test case contains M (1 < M < 100) positive
integers that you have to find the maximum of GCD.
Output
For each test case show the maximum GCD of every possible pair.
Sample Input
3
10 20 30 40
7 5 12
125 15 25
Sample Output
20
1
25
#include<cstdio>
#include<sstream>///istringstream的头文件
#include<iostream>
#include<string>
using namespace std;
typedef long long LL;
const int N=1e5+5;
int a[N];
int gcd(int a,int b)
{
return b==0?a:gcd(b,a%b);
}
int main()
{
int t;
cin>>t;
getchar();///读调回车
while(t--)
{
string str;
int cnt=0;
getline(cin,str);///按行读入
istringstream ist(str);//从string对象中读取空格,换行符分隔的字符
while(ist>>a[cnt])
cnt++;
int ans=0;
for(int i=0;i<cnt;i++)
for(int j=i+1;j<cnt;j++)
ans=max(ans,gcd(a[i],a[j]));
cout<<ans<<endl;
}
return 0;
}