C++习题(02)

一.Fibonacci数列

【程序说明】请将程序补充完整,并上机运行。用动态内在分配空间的方法计算Fibonacci数列的前20项并存储到动态分配的空间中。每行显示5个数据,数据间用’\t’分隔。

#include <iostream>
using namespace std;
int main()
{
	int *p = __(1)__ int[20];
	int *p1 = p;  //等价于int *p1;p1=p; 数组的地址赋给第一个元素
	*p = 1;
	*(p+1) = 1;
	cout<<*p<<"\t"<<*(p+1)<<"\t";
	p = p+2;
	for (int i=2; i<20;i++)
	{
		*p = __(2)__ ;
		cout<<*p<<"\t";
		if ((i+1)%5==0)
			cout<< __(3)__ ;
		p++;
	}
	__(4)__  p1;
	return 0;
} 

(1)new
首先是新开辟一些单元
(2) *(p-1) + *(p-2)
根据斐波那契数列,某一项的值是前2个数之和
(3)
‘\n’
每5个换行
(4)
delete
释放临时变量p

二.产品抽检

  1. (0分)

产品抽检题目描述
有1000台产品,编号依次为1~1000,要从中抽出15台进行抽样检测。请设计一个具有C++风格的抽样模拟程序,输出抽样结果,输出时要求每行输出5个数据,数据间’\t’分隔。(15台产品编号不重复)
【提示】产生15个1~1000间的随机数,请查阅srand()和rand()函数。
输入描述

输出描述
输出抽样结果,输出时要求每行输出5个数据,数据间’\t’分隔。
输入样例

输出样例
571 579 190 833 937
465 560 629 855 701
361 185 968 461 464

#include<iostream>
using namespace std;
int main()
{
	int a;
	int j=0;
	for(int i=0;i<15;i++)
	{
		a=(rand()%1000+1);
		cout<<a;
		j++;
		if(j%5==0) cout<<"\n";
		else cout<<"\t";
	}
	return 0;
}

随机数函数用法:
rand()%m是产生一个 0 到 m - 1 的随机数
想要生成 0到1000的
rand()%1000+1就行

三.swap() -函数重载、引用作函数参数

题目描述
编写C++风格的程序,建立swap()函数,重载该函数,分别用引用和指针做形参,实现两个整型数据的互换。
输入描述
两个整数
输出描述
依次调用两个重载函数后的两个整数值
输入样例
45 90
输出样例
引用作参数调用的结果:90 45
指针作参数调用的结果:45 90

#include<iostream>
using namespace std;
void swap(int &a,int &b)  //引用,交换两个变量
{
	int m;
	m=a;
	a=b;
	b=m;
}
void swap(int *a,int *b)//利用指针,交换两个变量,,形参就是变量的地址,使用时候要取地址
{
	int m;
	m=*a;
	*a=*b;
	*b=m;
}
int main()
{
	int a,b;
	cin>>a>>b;
	swap(a,b);
	cout<<"引用作参数调用的结果:"<<a<<" "<<b<<endl;
	swap(&a,&b);
	cout<<"指针作参数调用的结果:"<<a<<" "<<b<<endl;
	return 0;
}
交换两个值

如果是

void swap(int a,int b)  
{
	int m;
	m=a;
	a=b;
	b=m;
}

这样做就是没用的,形参不能改变实参的值!

四.换零钱

题目描述
编写一个C++的程序,解决换钱问题:将从键盘输入的人民币(以元为单位,可以为小数)兑换成1、2、5分的硬币,要求每种至少有一枚,有多少种换法?
输入描述
要换的钱数,以元为单元,可以是小数(double型数据)
输出描述
兑换后的换法总数
输入样例
1.5
输出样例
换法总数为:1066(中文冒号)

#include<iostream>
using namespace std;
int main()
{
	double i;
	int a,b,c,k=0;
	cin>>i;
	for(a=0;a<=(i*100);a++)//这里可以多的,这里是以300分作为最大的单位。。
	{
		for(b=0;b<=(i*50);b++)
		{
			for(c=0;c<=(i*20);c++)
			{
				if(a>0&&b>0&&c>0&&(a+b*2+c*5)==(i*100)) k++;//输入的是元,要化成分
			}
		}
	}
	cout<<"换法总数为:"<<k<<endl;
	return 0;
}

五.函数重载-sroot()

题目描述
编写一个C++风格的程序,建立sroot()函数,返回其参数的立方。重载sroot()3次,让它返回整数、长整数与双精度的立方,保留8位有效数字。(实数保留有效数字位数建议使用操纵符setprecision(8),头文件iomanip,使用方法网上查看相关文档)。
用cout输出时系统自动会根据数据大小选择小数或指数形式输出。
输入描述
三个数据,分别为基本整型、长整型、双精度实型
输出描述
三个双精度数:分别为整数、长整数与双精度的立方
输入样例
12
1234
12.34
输出样例
12的立方是:1728
1234的立方是:1.8790809e+009
12.34的立方是:1879.0809

#include<iostream>
#include<iomanip>
using namespace std;
double sroot(int a)
{
	return(a*a*a);
}
double sroot(long a)
{
	return(a*a*a);
}
double sroot(double a)
{
	return(a*a*a);
}
int main()
{
	int a;
	long b;
	double c;
	cin>>a;
	cin>>b;
	cin>>c;
	cout<<a<<"的立方是:"<<setprecision(8)<<sroot(a)<<endl;
	cout<<b<<"的立方是:"<<setprecision(8)<<sroot(b)<<endl;
	cout<<c<<"的立方是:"<<setprecision(8)<<sroot(c)<<endl;
	return 0;
}
  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

bmNkotc2AECynaY6

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值