asdf
By: asdf | Date: Nov 29 2007 22:27 | Format: C++ | Expires: never | Size: 3.82 KB | Hits: 1191
- #include <cstdlib>
- #include <iostream>
- #include <stack>
- #include <fstream>
- #include <queue>
- using namespace std;
- int main()
- {
- queue<string> q;
- queue<char> q2;
- stack<char> s;
- stack<char> s2;
- stack<char> s3;
- stack<char> s4;
- ifstream infile;
- ofstream outfile;
- char ch;
- char j;
- char r;
- string str;
- string sent;
- // int y; debugging purposes
- string k;
- infile.open("input5.txt");
- outfile.open("output5.txt");
- if(!infile)
- {
- cerr<< "NO FILE!!!!!!n";
- system("PAUSE");
- return 1;
- }
- while(getline(infile,str))
- {
- q.push(str); // queue of sentence
- }
- while(!q.empty())
- {
- sent = q.front(); // sets sent to first sentence
- // y = sent.size(); // checks size of first sentence
- // cout << y << endl;
- for (int m=0;m<sent.length();m++)
- {
- s.push(sent[m]); // puts first sentence into stack
- }
- while(!s.empty())
- {
- if(ispunct(s.top())) //finds punctuations and adds them to k
- {
- j = s.top(); //if punct, set j to punct
- k = (k +=j);
- s2.push(' ');
- }
- else
- s2.push(s.top());
- s.pop();
- }
- j = k[0];
- while(!s2.empty())
- {
- if(isspace(s2.top()))
- {
- s3.push(j);
- }
- else
- s3.push(s2.top());
- s2.pop();
- } //?lleh?eht??woh
- while(!s3.empty())
- {
- s.push(s3.top());
- s3.pop();
- } //how??the?hell?
- cout << q.size(); // this still says i have the last
- // sentence in but will not output
- while(!s.empty())
- {
- s4.push(s.top());
- s.pop();
- if(ispunct(s4.top()))
- {
- r = s4.top();
- s4.pop();
- while(!s4.empty())
- {
- q2.push(s4.top());
- s4.pop();
- }
- q2.push(r);
- }
- else if(isspace(s4.top()))
- {
- s4.pop();
- while(!s4.empty())
- {
- q2.push(s4.top());
- s4.pop();
- }
- q2.push(' ');
- }
- }
- while(!q2.empty())
- {
- cout << q2.front();
- q2.pop();
- }
- cout << endl << endl;
- k.clear();
- q.pop();
- }
- system("PAUSE");
- return EXIT_SUCCESS;
- }
Latest pastes
7 hours ago
1 days ago
3 days ago
3 days ago
3 days ago