实验作业
1.调试分析课本每一个例题,有可能的话更改成2-3个方法的新程序;
2.编程实现课本每一个编程习题。
3. 编程定义一个4X5矩阵和5X3矩阵,并计算它们的积。
4.编程输出1到n的平方的自然数构成的“魔方阵”,魔方阵是指它每一行和每一列及对角线之和均相等的方阵。
5.积累调试程序经验,收集错误信息原因(每个同学收集3-5条错误信息原因,并输入电脑形成文字)。
一、课本例题
版本1
/*** 最大值输出 ***/
#include <iomanip>
#include <iostream>
using namespace std;
int main()
{
int a[10],i,big;
cout<<"please input 10 numbers:\n";
for(i=0;i<10;i++)
cin>>a[i];
big=a[0];
for(i=1;i<10;i++)
if(a[i]>big)
big=a[i];
cout<<"the big number is:"<<big<<endl;
return 0;
}
版本2
/*** 沉石排序法 ***/
#include <iostream>
#include <iomanip>
using namespace std;
int main()
{
int a[5];
int i,j,t;
cout<<"请输入5个数字:\n";
for(i=0;i<5;i++)
cin>>a[i];
cout<<"这5个数字分别是:";
for(i=0;i<5;i++)
cout<<setw(4)<<a[i];
cout<<endl;
for(i=0;i<4;i++)
for(j=0;j<4-i;j++)
if(a[j]<a[j+1])
{t=a[j+1];a[j+1]=a[j];a[j]=t;}
cout<<"排列顺序为:";
for(i=0;i<5;i++)
cout<<setw(4)<<a[i];
cout<<endl;
return 0;
}
二、课本习题
1
/*** 冒泡排序法 ***/
#include <iostream>
#include <iomanip>
using namespace std;
int main()
{
int a[5];
int i,j,t;
cout<<"请输入5个数字:\n";
for(i=0;i<5;i++)
cin>>a[i];
cout<<"这5个数字分别是:";
for(i=0;i<5;i++)
cout<<setw(4)<<a[i];
cout<<endl;
for(i=0;i<4;i++)
for(j=0;j<4-i;j++)
if(a[j]>a[j+1])
{t=a[j];a[j]=a[j+1];a[j+1]=t;}
cout<<"排列顺序为:";
for(i=0;i<5;i++)
cout<<setw(4)<<a[i];
cout<<endl;
return 0;
}
2
、** 数组最大值和下标 **/
#include <iostream>
using namespace std;
int main()
{
int a[2][3],i,j,k,l;
int max=0;
cout<<"请输入6个任意整数值:"<<endl;
for (i=0;i<2;i++)
for(j=0;j<3;j++)
cin>>a[i][j];
for (i=0;i<2;i++)
for(j=0;j<3;j++)
{
if(a[i][j]>max)
{ max=a[i][j];
k=i;
l=j;
}
}
cout<<"该组最大的数是:"<<a[k][l]<<" 下标为:"<<k<<","<<l<<endl;
return 0;
}
3
/** Fibonacci数列 ***/
#include <iostream>
#include <iomanip>
using namespace std;
int main()
{
int i,j=0;
int f[40]={1,1};
for(i=2;i<40;i++)
f[i]=f[i-2]+f[i-1];
for(i=0;i<20;i++)
{
if(f[i]>100)
j++;
}
cout <<"Fibonacci数列前20个数中有 "<<j<<"个3位数,第16项为:"<<f[15];
cout <<endl;
return 0;
}
4
/*** 统计字符 ***/
#include <iostream>
#include <cctype>
using namespace std;
int main()
{
char words[50];
cout << "请输入字符(50字以内):"<<endl;
cin.get(words,50);
int i;
int up=0,low=0,blank=0,other=0,num=0;
for(i=0;words[i]!='\0';i++)
{
if(isupper(words[i]))
up++;
else if(islower(words[i]))
low++;
else if (words[i]==' ')
blank++;
else if(isdigit(words[i]))
num++;
else
other++;
}
cout << "字符中有 "<<up<<" 个大写字母, "<<low<<"个小写字母,"<<blank<<"个空格,"
<<num<<"个数字以及 "<<other<<"个其他字符。"<<endl;
return 0;
}
5
/*** 反向字符串 ****/
#include <cstring>
#include <iostream>
using namespace std;
int main()
{
char str[100];
cout<<"请输入一个字符串:";
cin.get(str,100);
cout<<"字符串"<<str<<"的反向字符串为:";
for (int i=strlen(str)-1;i>=0;i--) //strlen()为求字符串长度函数
cout<<str[i];
cout<<endl;
return 0;
}
三、矩阵乘积
#include <iostream>
#include <iomanip>
using namespace std;
int main()
{
int i,j,k;
int a[4][5]={{1,2,3,4,5},{5,6,7,8,9},{9,10,11,12,13},{13,14,15,16,17}};
int b[5][3]={{1,2,3},{5,6,7},{9,10,11},{13,14,15},{4,8,12}};
int c[4][3]={0};
cout<<"第一个矩阵:"<<endl;
for(i=0;i<4;i++){
for(j=0;j<5;j++)
cout<<setw(4)<<a[i][j];
cout<<endl;
}
cout<<"第二个矩阵:"<<endl;
for(i=0;i<5;i++){
for(j=0;j<3;j++)
cout<<setw(4)<<b[i][j];
cout<<endl;
}
for(i=0;i<4;i++)
for(k=0;k<3;k++)
for(j=0;j<5;j++)
c[i][k]+=a[i][j]*b[j][k];
cout<<"相乘的矩阵:"<<endl;
for(i=0;i<4;i++){
for(j=0;j<3;j++)
cout<<setw(4)<<c[i][j];
cout <<endl;
}
return 0;
}
五、积累调试经验
1 在使用i,j,k变量进行三层for循环嵌套时,应该注意i,j,k的最大值取值,有时候+1 或者-1 结果就不一样了。
2 在不同循环中,i ,j,k 是可以重复定义的。在for循环中,如果想要时变量的数值继承上面的数值,可以直接用 ; 省略代替掉。
3 这次作业做得不是很理想,有些题目还是解不出来,时间付出的不够,题目也越来越难,需要好好看书继续总结。