//program to arrange the string in decending order
#include%26lt;iostream.h%26gt;
#include%26lt;conio.h%26gt;
#include%26lt;string.h%26gt;
#include%26lt;stdio.h%26gt;
class des {
private:char ch[35],temp;
int len;
public: int get();
int sort(int);
int print(int);
};
int des::get()
{
cout%26lt;%26lt;"neter the st: ";
gets(ch);
len=strlen(ch);
return len;
}
int des::sort(int i)
{
for(int j=0;j%26lt;i-1;j++)
{ for(int k=j+1;k%26lt;j;k++)
{
if(ch[j]%26lt;ch[k])
{ temp=ch[j];
ch[j]=ch[k];
ch[k]=temp;
}
}
}
return i;
}
int des::print(int p)
{
for(int m=0;m%26lt;p;m++)
{ cout%26lt;%26lt;ch[m]; }
return 0;
}
void main()
{ clrscr();
des hi;
int a=0,b=0,c=0;
a=hi.get();
b=hi.sort(a);
hi.print(b);
getch();
}
Not getting the output?
Well here is a better version of your code:
#include %26lt;iostream%26gt;
#include %26lt;string%26gt;
#include %26lt;cstdlib%26gt;
using namespace std;
int main (void)
{
string str;
cout %26lt;%26lt; "Enter a string\t\t=%26gt; ";
getline(cin, str);
cout %26lt;%26lt; "The reversed string is\t=%26gt; ";
for (string::reverse_iterator i = str.rbegin(); i != str.rend(); ++i)
cout %26lt;%26lt; *i;
cout %26lt;%26lt; endl;
system("pause");
return EXIT_SUCCESS;
}
If you are using C++ and not C, then you should use the C++ Standard String Library. In addition, your code is not ANSI C++ since it uses the Borland Conio Library; if you are under Windows, then simply you can use under the stdlib library the function system("pause") instead of getch().
Remember that now under ANSI C++ using namespace std is the preferred way to do things. Finally as you can see the String Library uses the advanced features of STL including the reverse iterators. In our case we used the reverse_iterator specifying it to to start the traversal from the rbegin (synonym for "start at the end of the string") and end till the beginning of the string. It's important to realize that the string is NOT yet really reversed, we only displayed it in reversed order.
To actually reverse it in such the indexes are really changed rather than just displaying it in reversed order, then perhaps this is one of the ways:
#include %26lt;iostream%26gt;
#include %26lt;string%26gt;
#include %26lt;cstdlib%26gt;
using namespace std;
void reverse_string(string%26amp;);
int main (void)
{
string str;
cout %26lt;%26lt; "Enter a string\t\t=%26gt; ";
getline(cin, str);
cout %26lt;%26lt; "The reversed string is\t=%26gt; ";
reverse_string(str);
cout %26lt;%26lt; str %26lt;%26lt; endl;
system("pause");
return EXIT_SUCCESS;
}
void reverse_string(string%26amp; str)
{
string temp = "";
for (string::reverse_iterator i = str.rbegin(); i != str.rend(); ++i)
temp += *i;
str = temp;
return;
}
Hope it's helpful :-)
Regards
Coosa
Reply:Actually the problem in the logic. Try to modify it.
Subscribe to:
Post Comments (Atom)
No comments:
Post a Comment