| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2057 人关注过本帖
标题:[求助][原创] 自己定义一个string类,将字符反顺序排序后,显示出的是乱码
只看楼主 加入收藏
laigaoat2005
Rank: 4
等 级:业余侠客
帖 子:388
专家分:226
注 册:2007-4-5
收藏
得分:0 
希望洗个澡回来就有人帮我了
2007-06-22 21:56
野比
Rank: 7Rank: 7Rank: 7
等 级:贵宾
威 望:24
帖 子:1627
专家分:516
注 册:2007-5-24
收藏
得分:0 
你的temp数组定义大小为i
char temp[i];
所以temp[]的下标范围从0到i-1
你后面又使用了temp[i], 造成下标越界, 出现错误.

女侠,约吗?
2007-06-22 21:58
laigaoat2005
Rank: 4
等 级:业余侠客
帖 子:388
专家分:226
注 册:2007-4-5
收藏
得分:0 

哦,原来如此,谢谢,洗了澡我去修改看看,

2007-06-22 22:02
野比
Rank: 7Rank: 7Rank: 7
等 级:贵宾
威 望:24
帖 子:1627
专家分:516
注 册:2007-5-24
收藏
得分:0 
看看吧...希望只有这一个错..

女侠,约吗?
2007-06-22 22:06
aipb2007
Rank: 8Rank: 8
来 自:CQU
等 级:贵宾
威 望:40
帖 子:2879
专家分:7
注 册:2007-3-18
收藏
得分:0 
我在想char temp[i];
i是个变量的嘛!这也可以?

Fight  to win  or  die...
2007-06-22 22:23
laigaoat2005
Rank: 4
等 级:业余侠客
帖 子:388
专家分:226
注 册:2007-4-5
收藏
得分:0 
可是i的值已经确定了啊,而且我又没有去改变它,应试可以吧?
2007-06-23 14:35
laigaoat2005
Rank: 4
等 级:业余侠客
帖 子:388
专家分:226
注 册:2007-4-5
收藏
得分:0 

今天看了看昨天的这个题,发现了一相很大的错,今天改了改,但是还是不行,程序如下:
//============================================================================//
//===========程序功能:自己定义一个string类,并用它建立对象===================//
//===程序问题:将字符反顺序排序后,显示出的是知码,就算字符全部是字母也不行===//
//============================================================================//

#include "iostream.h"
#include "stdio.h"
//============================================================================//
//----------自定义字串类------------------------------------------------------//
class string
{
/******************************************************************************/
/**************私有数据********************************************************/
int length;
char *contents;
int who;
char *fan;

/******************************************************************************/
/**************公有数据********************************************************/
public:

/***构造函数***********************/
string(int id);

/***析构函数***********************/
~string();

/***用户界面************************/
int get_length(){return length;}; //返回字符串的长度
char *get_contents() {return contents;}; //返回字符串的内容的指针
char *get_fan()
{
char temp[length];
int j=0;
for(j=0; j<((length-1)/2);j++)
{
char t;
t=temp[j];
temp[j]=temp[length-j-2];
temp[length-j-2]=t;
}
fan=temp;
return fan;
}; //返回字符串的返排列的字符串的指针
int set_contents(int in_length,char *in_contents); //字符内容设置(从终端或其它地方接收参数)
int set_contents(char *in_contents); //字符内容设置(从终端或其它地方接收参数)
};

/***类函数(对数据进行操作)*******************/
string:: string(int id)
{
length=0;
contents=NULL;
fan=NULL;
who=id;
printf("字串对象%d已经初始化!\n\a",who);
};

string:: ~string()
{
printf("字串对象%d已经释放!\n\a",who);
};


int string::set_contents(int in_length,char *in_contents)
{
in_contents[in_length]='\0';
contents=in_contents;
fan=in_contents;
length=in_length;
return 1;
};

int string:: set_contents(char *in_contents)
{
contents=in_contents;
fan=in_contents;
int i=0;
char *p=in_contents;
while(*p++!='\n')i++;
length=i;


/******我想加个将输入的字符串按相反顺序排列,可排出来是乱码!*****************/
/* int j=0;
char temp[length];
for(j=0; j<((length-1)/2);j++)
{
char t;
t=temp[0];
temp[0]=temp[length-1];
temp[length]=t;
}
fan=temp; */
return 1;
};

//----------------------------------------------------------------------------//
//============================================================================//

//((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((//
//))主函数))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))//
main()
{
int i;
char *p;
string x(1),y(2);
x.set_contents("abc"); //大家好,这是自己编的类写出来的字串\n\n\a
y.set_contents("abc"); //大家好,这是自己编的类写出来的字串\n\n\a
i=x.get_length();
p=x.get_contents();
cout<<"x_length="<<i<<" x_contents="<<p<<"\n\a";
i=y.get_length();
p=y.get_contents();
cout<<"y_length="<<i<<" y_contents="<<p<<"\n\a";

p=x.get_fan();
cout<<"x.fan="<<p<<"\n";
p=y.get_fan();
cout<<"y.fan="<<p<<"\n";
getchar();
}
//((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((((//
//))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))))//

2007-06-23 14:44
herbert_1987
Rank: 5Rank: 5
等 级:贵宾
威 望:15
帖 子:1314
专家分:0
注 册:2007-5-13
收藏
得分:0 

int string:: set_contents(char *in_contents)
{
contents=in_contents;
fan=in_contents;
int i=0;
char *p=in_contents;
while(*p++!='\n')i++;
length=i;


/******我想加个将输入的字符串按相反顺序排列,可排出来是乱码!*****************/
/* int j=0;
char temp[length];
for(j=0; j<((length-1)/2);j++)
{
char t;
t=temp[0];
temp[0]=temp[length-1];
temp[length]=t;
}
fan=temp; */
return 1;
};

char temp[length]; 是不行的
估计下标要要求用立即数.


人生重要的不是所站的位置,而是所朝的方向
2007-06-23 14:51
laigaoat2005
Rank: 4
等 级:业余侠客
帖 子:388
专家分:226
注 册:2007-4-5
收藏
得分:0 
不,我试过的,只要变量值确定,就可以的
2007-06-24 10:42
游乐园
Rank: 3Rank: 3
等 级:新手上路
威 望:6
帖 子:671
专家分:0
注 册:2006-11-1
收藏
得分:0 

怎么静态数组的维数用变量指定呢 ? 写个大概的...参考下吧

程序代码:

#include<string.h>
#include<iostream.h>

class string;
ostream & operator<<(ostream &output, string &s);
istream & operator>>(istream &input, string &s);

class string
{

public:
string(char *m = \"\");
char* reverseStr();
friend ostream & operator<<(ostream &output, string &s);
friend istream & operator>>(istream &input, string &s);
~string();
private:
char *str;

};

string::string(char *m)
{
str = new char[strlen(m)+1];
strcpy(str, m);
}

string::~string() {delete []str;}

char* string::reverseStr()
{
char *p1, *p2, ch;
p1 = p2 = str;
while(*p2 != '\0')
p2++;
p2--;
while(p1 < p2)
{
ch=*p2;*p2=*p1;*p1=ch;
p1++;p2--;
}
return str;
}

ostream & operator<<(ostream &output, string &s)
{
output<<s.str;
return output;
}

istream & operator>>(istream &input, string &s)
{
char temp[1000];
input>>temp;
delete []s.str;
s.str=new char[strlen(temp)+1];
strcpy(s.str,temp);
return input;
}


int main()
{
string s;
cout<<\"input :\"<<endl;
cin>>s;
cout<<\"output :\"<<endl;
cout<<s;
cout<<\"\nafter reversed: \"<<s.reverseStr()<<endl;

return 0;
}


unicorn-h.spaces. ◇◆ sava-scratch.spaces.
2007-06-24 19:39
快速回复:[求助][原创] 自己定义一个string类,将字符反顺序排序后,显示出的是乱 ...
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.034955 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved