第四章实验作业

实验作业

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 这次作业做得不是很理想,有些题目还是解不出来,时间付出的不够,题目也越来越难,需要好好看书继续总结。






  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值