吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 2477|回复: 1
收起左侧

[C&C++ 转载] STL容器vector与迭代器istream_iterator<>的使用

[复制链接]
Rain_Personal 发表于 2017-7-27 19:04
这段时间重新复习了一下C++语言程序设计(第4版)郑莉写的,里面有一段代码关于奇偶排序的,用VC6.0编译无法通过,自己琢磨了一下修改了一下代码实现了代码的运行。具体代码如下:
#include <vector>
#include <deque>
#include <algorithm>
#include <iterator>
#include <iostream>
using namespace std;

int main()
{
        istream_iterator<int>i1(cin),i2;//建立一对输入流迭代器
        vector<int>s1(i1,i2);               //通过输入流迭代器从标准输入流中输入数据
        sort(s1.begin(),s1.end());        //将输入的整数排序
        deque<int>s2;
        for (vector<int>::iterator iter=s1.begin();iter!=s1.end();++iter)
        {
                if (*iter%2==0)               //偶数放到s2尾部
                {
                        s2.push_back(*iter);
                }
                else                                 //奇数放到s2尾部
                {
                        s2.push_front(*iter);
                }
        }
        //将s2的结果输出
        copy(s2.begin(),s2.end(),ostream_iterator<int>(cout," "));
        cout<<endl;
        return 0;
}
书上虽有说vector s(q1,q2);这种用法。(将[q1,q2)区间的数据作为s的元素构造s。)
但是编译无法通过就得改,改的能通过。以下是我修改的代码:
#include <vector>
#include <deque>
#include <algorithm>
#include <iterator>
#include <iostream>
using namespace std;

int main()
{
        istream_iterator<int>i1(cin),i2;
        vector<int>s1;//由于无法通过vector s(q1,q2);对向量容器进行赋值所以先声明,再迭代赋值。
        while (i1!=i2)
        {
                s1.push_back(*i1++);
        }
        sort(s1.begin(),s1.end());
        deque<int>s2;
        for (vector<int>::iterator iter=s1.begin();iter!=s1.end();++iter)
        {
                if (*iter%2==0)
                {
                        s2.push_back(*iter);
                }
                else
                {
                        s2.push_front(*iter);
                }
        }
        copy(s2.begin(),s2.end(),ostream_iterator<int>(cout," "));
        cout<<endl;
        return 0;
}
不太完美的地方是运行的结尾必须是字符串结尾加回车才可以。没有去找参数的原型,懂得小伙伴一起交流交流。怎么改善?给出运行的截图吧

运行结果截图

运行结果截图

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

ningfei 发表于 2017-7-27 19:22 来自手机
沙发走起
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-27 02:42

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表