注册 登录
编程论坛 C++教室

后置自增操作符号哪里使用错了。

未未来 发布于 2013-02-18 23:38, 643 次点击
程序代码:
#include<iostream>
#include<string>
#include<vector>
using namespace::std;
int main(){

 vector<string*>vec;

 string str;

 cout<<"Enter some string ,"<<endl;

 while(cin>>str){
     string *st= new string;
     *st=str;
     vec.push_back(st);

 }   
vector<string*>::iterator iter=vec.begin();
while(iter!=vec.end()){
cout<<**iter++<<"   "<<(**iter++).size()<<endl;
;
}
while(iter!=vec.end()){
   
delete *iter++;

}
return 0;
}
7 回复
#2
peach54602013-02-19 08:19
cout<<**iter++<<"   "<<(**iter++).size()<<endl;
加了又加?
#3
rjsp2013-02-19 09:13
提个问题这么难?这是幼儿园就应该学会的技能,现在好多大学生提问时怎么无前后文、又前言不搭后语,就像在梦游一般?

“后置自增操作符号哪里使用错了。”
----- 第一,你这段代码怎么错了,你先得描述一下错误现象,比如 这段代码无法编译通过,报某某行某某错误;又或 这段代码编译出的程序运行时报错,运行时输入的数据是什么什么。
第二,你确定你这段代码引发的错误(比如上述的编译错误或运行错误)是由于自增操作符号使用错了?我不明白你为什么要给自己下套子

程序代码:
#include <iostream>
#include <string>
#include <vector>
using namespace std;

int main()
{
    vector<string*> vec;

    for( string str; cin>>str; )
    {
        string* st = new string;
        st->swap( str );
        vec.push_back( st );
    }
   

    for( vector<string*>::const_iterator itor=vec.begin(); itor!=vec.end(); ++itor )
        cout << **itor << "   " << (**itor).size() << endl;

    for( vector<string*>::iterator itor=vec.begin(); itor!=vec.end(); ++itor )
        delete *itor;

    return 0;
}

#4
peach54602013-02-19 11:32
以下是引用rjsp在2013-2-19 09:13:35的发言:

提个问题这么难?这是幼儿园就应该学会的技能,现在好多大学生提问时怎么无前后文、又前言不搭后语,就像在梦游一般?

“后置自增操作符号哪里使用错了。”
----- 第一,你这段代码怎么错了,你先得描述一下错误现象,比如 这段代码无法编译通过,报某某行某某错误;又或 这段代码编译出的程序运行时报错,运行时输入的数据是什么什么。
第二,你确定你这段代码引发的错误(比如上述的编译错误或运行错误)是由于自增操作符号使用错了?我不明白你为什么要给自己下套子

#include <iostream>
#include <string>
#include <vector>
using namespace std;

int main()
{
    vector<string*> vec;

    for( string str; cin>>str; )
    {
        string* st = new string;
        st->swap( str );
        vec.push_back( st );
    }
   

    for( vector<string*>::const_iterator itor=vec.begin(); itor!=vec.end(); ++itor )
        cout << **itor << "   " << (**itor).size() << endl;

    for( vector<string*>::iterator itor=vec.begin(); itor!=vec.end(); ++itor )
        delete *itor;

    return 0;
}


淡定,现在提问题的都是爹...
人家觉得我们就该跟在屁股后面求着他提问题...
#5
未未来2013-02-19 16:36
回复 2楼 peach5460
谢谢, 问题已经解决了。,
#6
fanpengpeng2013-02-19 16:59
回复 楼主 未未来
是不是在释放内存的时候,迭代器没有重新指向vec.begin()啊
#7
Susake2013-02-19 17:11
曾分啦
#8
两条线2232013-03-05 21:41
新手来看看哈哈
1