c++primer第五版 练习5.17

来源:互联网 发布:大数据平台 数据管理 编辑:程序博客网 时间:2024/06/07 17:22

如何让自由输入让两个vector长度不一致

如果单纯按例子来编写程序未免也太不能发散思维了。。

书中介绍的初始化vector方法有 。。
1 ,使用列表初始化
2,使用传统for语句限定长度用push_back输入。。
然而弊端很明显
首先两vector长度被你认为选定了
3,使用while循环。。
这倒实现了vector不限定长度的问题。。
但让vector还是不太容易 ,或者像我之前一样只能使一个vector比另一个多1个元素 而已。
需要合理处置 ctrl z才能达到任意长度的两vector ;

程序如下

#include<iostream>#include<vector>#include<cstdlib>using namespace std;int main(){    vector<int> v1,v2;    int a=0,b=0;    while(cin>>a)       v1.push_back(a);    cin.clear();      // 清除ctrl z 状态 让 cin>>b能进行下去     while(cin>>b)       v2.push_back(b);    if(v1.size()<v2.size())    {    int i=0;        for(; i!=v1.size()&&v1[i]==v2[i];++i)        {             ;        }        if(i==v1.size())        {            cout<<" v1为v2的前缀 "<<endl;            cout<<" 结果为真 "<<endl;         }        else              cout<<" 结果为假 "<<endl;     }    else    {        int i=0;        for(; i!=v2.size()&&v1[i]==v2[i];++i)        {             ;        }        if(i==v2.size())        {            cout<<"v2为v1的前缀"<<endl;             cout<<" 结果为真 "<<endl;        }        else            cout<<" 结果为假 "<<endl;     }    return 0;} 

下面引用大神对 ctrl z的解释

连续输入的问题两个vector,怎么输入也不对,在http://topic.csdn.net/u/20071205/18/1bd3981a-33b2-4724-a08c-cadad427a365.html找到了答案。下面的解释摘自liuyw813。
输入缓冲是行缓冲。当从键盘上输入一串字符并按回车后,这些字符会首先被送到输入缓冲区中存储。每当按下回车键后,cin.get() 就会检测输入缓冲区中是否有了可读的数据。cin.get() 还会对键盘上是否有作为流结束标志的 Ctrl+Z 或者 Ctrl+D 键按下作出检查,其检查的方式有两种:阻塞式以及非阻塞式。

阻塞式检查方式指的是只有在回车键按下之后才对此前是否有 Ctrl+Z 组合键按下进行检查,非阻塞式样指的是按下 Ctrl+D 之后立即响应的方式。如果在按 Ctrl+D 之前已经从键盘输入了字符,则 Ctrl+D的作用就相当于回车,即把这些字符送到输入缓冲区供读取使用,此时Ctrl+D不再起流结束符的作用。如果按 Ctrl+D 之前没有任何键盘输入,则 Ctrl+D 就是流结束的信号。

Windows系统中一般采用阻塞式检查 Ctrl+Z、Unix nux系统下一般采用非阻塞式的检查 Ctrl+D。楼主是在Windows系统下,因此使用阻塞式的 Ctrl+Z 来标识流的结束。

这种阻塞式的方式有一个特点:只有按下回车之后才有可能检测在此之前是否有Ctrl+Z按下。还有一个特点就是:如果输入缓冲区中有可读的数据则不会检测Ctrl+Z(因为有要读的数据,还不能认为到了流的末尾)。还有一点需要知道:Ctrl+Z产生的不是一个普通的ASCII码值,也就是说它产生的不是一个字符,所以不会跟其它从键盘上输入的字符一样能够存放在输入缓冲区。明白了这几点之后就可以来解释楼主提出的问题了。

从键盘上输入abcd^z 加 回车之后在Windows系统上是这样处理的:由于回车的作用,前面的 abcd 等字符被送到输入缓冲区(注意:上面说过了,^z不会产生字符,所以更不会存储到输入缓冲区,缓冲区中没有 ^z 的存在)。这时,cin.get() 检测到输入缓冲区中已经有数据存在(因此不再检查是否有 ^z 的输入),于是从缓冲中读取相应的数据。如果都读取完了,则输入缓冲区重新变为空,cin.get() 等待新的输入。可见,尽管有 ^z 按下,但是由于在此之前还有其它输入字符(abcd),所以流也不会结束。

由本人粗略解释下

输入

^z 表示 按下ctrl z产生的东西

123^z +回车

当我们这么输入时,首先 123被送到输入缓冲区,系统检测到缓冲区有数据而

忽略^z

但当我们按下输入时

123 +回车 (会跳转到下一行)
^z +回车

此时123依旧被送入输入缓冲区,然后读完这些数据后,缓冲区清空

清空!!!
然后此时
输入 ^z (缓冲区清空,已经没可读数据了)
就能达到终止输入效果了、

关于cin.clear()

引用博主的blog

https://www.cnblogs.com/tonglingliangyong/p/3908463.html

我对cin.clear()理解是让恢复默认值,恢复正常操作
可配合 cin.sync()清空流使用。。。

如果不需要完全清流可以使用 这位大神提到的
http://blog.csdn.net/lann64/article/details/3544479
ignore函数

当然清空是全清 类似的函数还有 system(clz)清屏指令