首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > C++ >

杭电这题为何一直RE郁闷

2012-09-05 
杭电这题为什么一直RE郁闷啊#includeiostream#includevector#includeiomanipusing namespace stdvo

杭电这题为什么一直RE郁闷啊
#include<iostream>
#include<vector>
#include<iomanip>
using namespace std;
void main()
{
double n,m;
while(cin>>n>>m)
{
vector<vector <int> >a(n,vector<int>(m));
double st_sum,su_sum;
double *st_ave=new double [n];
double *su_ave=new double [m];

for(int i=0;i<n;i++)
for(int j=0;j<n;j++)
cin>>a[i][j];
for(int i=0;i<n;i++)
{
st_sum=0;
for(int j=0;j<n;j++)
{

st_sum+=a[i][j];
st_ave[i]=st_sum/m;
}
}
for(int j=0;j<m;j++)
{
su_sum=0;
for(int i=0;i<n;i++)
{
su_sum+=a[i][j];
su_ave[j]=su_sum/n;
}

}
int digit=0;
for(int i=0,j;i<n;i++)
{
for(j=0;j<m;j++)
{
if(a[i][j]<su_ave[j])
break;
}
if(j>=m)
digit++;
}
bool k=false;
for(int i=0;i<n;i++)
{
if(k!=false)
cout<<" ";
k=true;
cout.setf(ios::fixed);
cout<<setprecision(2)<<st_ave[i];
}
cout<<endl;
bool p=false;
for(int i=0;i<m;i++)
{
if(p!=false)
cout<<" ";
p=true;
cout.setf(ios::fixed);
cout<<setprecision(2)<<su_ave[i];
}
delete []su_ave;
delete []st_ave;
cout<<endl;
cout<<digit<<endl<<endl;

}
system("pause");
}
题目
假设一个班有n(n<=50)个学生,每人考m(m<=5)门课,求每个学生的平均成绩和每门课的平均成绩,并输出各科成绩均大于等于平均成绩的学生数量。
 

Input
输入数据有多个测试实例,每个测试实例的第一行包括两个整数n和m,分别表示学生数和课程数。然后是n行数据,每行包括m个整数(即:考试分数)。
 

Output
对于每个测试实例,输出3行数据,第一行包含n个数据,表示n个学生的平均成绩,结果保留两位小数;第二行包含m个数据,表示m门课的平均成绩,结果保留两位小数;第三行是一个整数,表示该班级中各科成绩均大于等于平均成绩的学生数量。
每个测试实例后面跟一个空行。
 

Sample Input
2 2
5 10
10 20
 

Sample Output
7.50 15.00
7.50 15.00
1

[解决办法]
改3行AC:
#include<iostream>
#include<vector>
#include<iomanip>
using namespace std;
void main()
{
 double n,m;
 while(cin>>n>>m)
 {
 vector<vector <int> >a(n,vector<int>(m));
 double st_sum,su_sum;
 double *st_ave=new double [n];
 double *su_ave=new double [m];

 for(int i=0;i<n;i++)
 for(int j=0;j<m;j++)//for(int j=0;j<n;j++)
 cin>>a[i][j];
 for(int i=0;i<n;i++)
 {
 st_sum=0;
 for(int j=0;j<m;j++)//for(int j=0;j<n;j++)
 {

 st_sum+=a[i][j];
 st_ave[i]=st_sum/m;
 }
 }
 for(int j=0;j<m;j++)
 {
 su_sum=0;
 for(int i=0;i<n;i++)
 {
 su_sum+=a[i][j];
 su_ave[j]=su_sum/n;
 }

 }
 int digit=0;
 for(int i=0,j;i<n;i++)
 {
 for(j=0;j<m;j++)
 {
 if(a[i][j]<su_ave[j])
 break;
 }
 if(j>=m)
 digit++;
 }
 bool k=false;
 for(int i=0;i<n;i++)
 {
 if(k!=false)
 cout<<" ";
 k=true;
 cout.setf(ios::fixed);
 cout<<setprecision(2)<<st_ave[i];
 }
 cout<<endl;
 bool p=false;
 for(int i=0;i<m;i++)
 {
 if(p!=false)
 cout<<" ";
 p=true;
 cout.setf(ios::fixed);
 cout<<setprecision(2)<<su_ave[i];


 }
 delete []su_ave;
 delete []st_ave;
 cout<<endl;
 cout<<digit<<endl<<endl;

 }
 //system("pause");
}

热点排行