找回密码
 注册
搜索
热搜: 回贴
  • 前程无忧官网首页 有什么好的平台可以
  • 最新的销售平台 互联网营销的平台有哪
  • 制作网页的基本流程 网页制作和网页设
  • 【帝国CMS】输出带序号的列表(数字排
  • 网站建设公司 三一,中联,极东泵车的
  • 织梦 建站 织梦网站模版后台怎么更改
  • 云服务官网 哪些网站有免费的简历模板
  • 如何建网站要什么条件 建网站要用什么
  • 吉林市移动公司电话 吉林省退休人员网
  • 设计类毕业论文 网站设计与实现毕业论
查看: 484|回复: 4

[求助]这个运行错误是怎么回事?

[复制链接]
发表于 2009-11-3 02:27:02 | 显示全部楼层 |阅读模式 IP:江苏扬州
是一个文字分类的题目
从一个文件中读入字符(只包含小写的字母a~z),将字符分类,并计算每类的个数和百分比,并按百分比大小排序,
将排序好的字符,按字符 个数 百分比格式存入文件中,下面是我的程序,请大家调试的时候先在C盘建一个名为test的文本
文件,出现的错误是字符根本就没有排序,我是初学者,请大家赐教!
# include<iostream.h>
# include<fstream.h>
int main()
{
ifstream ifile("c:\\test.txt");
if (!ifile)
{
cout<<"cannot open test"<<endl;
return 0;
}
char ch,sh='a';
int i,j;
float zongshu=0;
struct jiegou
{
char zifu;
int num;
float per;
};
jiegou a[26],sump;
for (i=0;i<=25;i++)
{
a[i].zifu=sh++;
a[i].num=0;
a[i].per=0;
}
while(ifile)
{
ifile.get(ch);
zongshu=zongshu+1;
a[ch-'a'].num=a[ch-'a'].num+1;
}
ifile.close();
for (i=0;i<=25;i++)
a[i].per=100*a[i].num/zongshu;
for (i=0;i<=25;i++)
{
if ((a[i].per>a[i+1].per)||((a[i].per=a[i+1].per) && (a[i].zifu>a[i+1].zifu)))
{
sump=a[i];
a[i]=a[i+1];
a[i+1]=sump;
}
}
for (i=0;i<=25;i++)
{
cout<<a[i].zifu<<" "<<a[i].num<<" "<<a[i].per<<'%'<<endl;
}
ofstream ofile ("c:\\jieguo.txt");
if (!ofile)
{
cout << "test file cannot be opened" << endl;
return 0;
}
for (i=0; i<25; i++)
{
ofile <<a[i].zifu<<" "<<a[i].num<<" "<<a[i].per<<'%'<<endl;
}
ofile.close();
return 1;
}
发表于 2009-11-3 02:27:03 | 显示全部楼层 IP:江苏扬州
这是什么排序算法?
回复

使用道具 举报

发表于 2009-11-3 02:27:04 | 显示全部楼层 IP:江苏扬州
就是这个排序出的问题,我改了好多次都不行,最后一次改成这样,我没有办法了,只能向大家求助了
回复

使用道具 举报

发表于 2009-11-3 02:27:05 | 显示全部楼层 IP:江苏扬州
你用的排序是有问题,按照你这样排,得到的百分比最大的字符(排在最后面)
回复

使用道具 举报

发表于 2009-11-3 02:27:07 | 显示全部楼层 IP:江苏扬州
以下是引用rongrong在2006-5-26 20:54:00的发言:

是一个文字分类的题目
从一个文件中读入字符(只包含小写的字母a~z),将字符分类,并计算每类的个数和百分比,并按百分比大小排序,
将排序好的字符,按字符 个数 百分比格式存入文件中,下面是我的程序,请大家调试的时候先在C盘建一个名为test的文本
文件,出现的错误是字符根本就没有排序,我是初学者,请大家赐教!
# include<iostream.h>
# include<fstream.h>
int main()
{
ifstream ifile("c:\\test.txt");
if (!ifile)
{
cout<<"cannot open test"<<endl;
return 0;
}
char ch,sh='a';
int i,j;
float zongshu=0;
struct jiegou
{
char zifu;
int num;
float per;
};
jiegou a[26],sump;
for (i=0;i<=25;i++)
{
a[i].zifu=sh++;
a[i].num=0;
a[i].per=0;
}
while(ifile)
{
ifile.get(ch);
zongshu=zongshu+1;
a[ch-'a'].num=a[ch-'a'].num+1;
}
ifile.close();
for (i=0;i<=25;i++)
a[i].per=100*a[i].num/zongshu;
for(j=0;j<25;j++) //这个地方需要加一个循环来控制,调整剩下的元素
{
for (i=0;i<25-j;i++) //要通过j来调整i的循环范围
{
if ((a[i].per>a[i+1].per)||((a[i].per=a[i+1].per) && (a[i].zifu>a[i+1].zifu)))
{
sump=a[i];
a[i]=a[i+1];
a[i+1]=sump;
}
}
}
for (i=0;i<=25;i++)
{
cout<<a[i].zifu<<" "<<a[i].num<<" "<<a[i].per<<'%'<<endl;
}
ofstream ofile ("c:\\jieguo.txt");
if (!ofile)
{
cout << "test file cannot be opened" << endl;
return 0;
}
for (i=0; i<25; i++)
{
ofile <<a[i].zifu<<" "<<a[i].num<<" "<<a[i].per<<'%'<<endl;
}
ofile.close();
return 1;
}
主要是这里没处理好
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|小黑屋|最新主题|手机版|微赢网络技术论坛 ( 苏ICP备08020429号 )

GMT+8, 2024-9-30 09:30 , Processed in 0.251142 second(s), 12 queries , Gzip On, MemCache On.

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表