c++实验2(1.重载的函数 2.const关键字 3.动态内存分配利用new运算分配内存空间,利用delete运算或程序运行结束释放内存。)

简介: 编写程序,定义2个重载函数add并在main函数中应用,功能。编写重载函数并验证,函数功能:对数组赋值。.编写程序,利用动态内存进行数据存储,实现功能:输入2个数据分别表示矩形的长和高,输出矩形的周长和面积。

2.编写程序,定义2个重载函数add并在main函数中应用,功能分别为:


①实现两个浮点数据相加,并返回结果;


②实现一个整型数据的自加1,并返回结果


#include<iostream>
using namespace std;
float add(float x,float y)
{
  return (x+y);
}
int add(int x)
{
  return (x+1);
}
int main()
{
  int x,y;
  cout<<"请输入两个数"<<endl;
  cin>>x>>y;
  cout<<add(x,y)<<'\t'<<add(x)<<endl;
  system("pause");
  return 0
}

3.编写重载函数并验证,函数功能:对数组赋值。


①bool setarr(int *desp, int descnt, const int * const scrp, int scrcnt);


说明:desp为目的数组, descnt为目的数组长度,scrp为源数组,scrcnt为源数组长度;


当源数组长度>=目的数组长度,将源数组元素对应赋值给目的数组元素,返回true;

否则返回false。


补充:bool是C++的数据类型,逻辑型,只有2个取值:true和false。


②void setarr(int *desp, int descnt, int x=0);


说明:desp为目的数组, descnt为目的数组长度,x为赋值数据,


将目的数组的所有元素均赋值为x。


③void setarr(int *desp, int descnt, int min, int max);


说明:desp为目的数组, descnt为目的数组长度,min、max为数组元素取值的范围,

将目的数组元素赋值为取值介于min和max之间的随机数。(提示:查阅MSDN,掌握rand函数)


#include<iostream>
using namespace std;
/*
  ①bool setarr(int *desp, int descnt, const int * const scrp, int scrcnt);
说明:desp为目的数组, descnt为目的数组长度,scrp为源数组,scrcnt为源数组长度;
      当源数组长度>=目的数组长度,将源数组元素对应赋值给目的数组元素,返回true;
    否则返回false。
  */
bool setarr(int *desp, int descnt, const int * const scrp, int scrcnt)
{
  if(scrcnt>=descnt)
  {
    for(int i=0;i<descnt;i++)
      desp[i]=scrp[i];
    return 1;
  }
  else
    return 0;
}
/*
②void setarr(int *desp, int descnt, int x=0);
说明:desp为目的数组, descnt为目的数组长度,x为赋值数据,
      将目的数组的所有元素均赋值为x。
*/
void setarr(int *desp, int descnt, int x=0)
{
  int i,n;
  for(i=0;i<descnt;i++)
    desp[i]=x;
  for(n=0;n<descnt;n++)
    cout<<desp[n]<<' ';
}
/*
③void setarr(int *desp, int descnt, int min, int max);
说明:desp为目的数组, descnt为目的数组长度,min、max为数组元素取值的范围,
将目的数组元素赋值为取值介于min和max之间的随机数。
*/
void setarr(int *desp, int descnt, int min, int max)
{
  int i;
  for(i=0;i<descnt;i++)
    desp[i]=min+1+rand()%(max-min);
  for(i=0;i<descnt;i++)
    cout<<desp[i]<<' ';
}
int main()
{
  int desrp[10]={1,2,3,4,5,6,7,8,9,10};
  int descnt=10;//目的数组和长度
  int scrp[11]={10,9,8,7,6,5,4,3,2,1,0};
  int scrcnt=11;//源数组和长度
  bool i;//判断真假
  int x,min,max,n,j;//值,min、max为数组元素取值的范围。
  cout<<"改变前\n目的数列:";
  for(n=0;n<descnt;n++)
    cout<<desrp[n]<<' ';
  cout<<"\t源数组:";
  for(j=0;j<scrcnt;j++)
    cout<<scrp[j]<<' ';
  cout<<'\n';
  cout<<"输出真(1)假(0)"<<endl;
  i=setarr(desrp,descnt,scrp,scrcnt);
  cout<<i<<endl;
  cout<<"改变后\n目的数列:";
  for(n=0;n<descnt;n++)
    for(n=0;n<descnt;n++)
    cout<<desrp[n]<<' ';
  cout<<"\t源数组:";
  for(j=0;j<scrcnt;j++)
    cout<<scrp[j]<<' ';
  cout<<'\t';
  cout<<"\n输入一个数字\n";
  cin>>x;
  cout<<"赋值后目的数组:";
  setarr(desrp,descnt,x);
  cout<<endl;
  cout<<"min、max为数组元素取值的范围请输入对应的值:\t";
  cin>>min>>max;
  cout<<"\n取随机数后的目的数组是:";
  setarr(desrp,descnt,min,max);
  system("pause");
  return 0;
}


4.编写程序,利用动态内存进行数据存储,实现功能:输入2个数据分别表示矩形的长和高,输出矩形的周长和面积。


#include<iostream>
#include<malloc.h>
using namespace std;
int main()
{
  int *p;
  p=new int[2];
  cout<<"请输入矩形的长和宽"<<endl;
  for(int i=0;i<2;i++)
    cin>>p[i];
  cout<<"周长是:"<<(2*(p[0]+p[1]))<<endl;
  cout<<"面积是:"<<(p[0]*p[1])<<endl;
  delete[] p;
  system("pause");
  return 0;
}
目录
相关文章
|
1月前
|
存储 开发框架 .NET
"揭秘.NET内存奥秘:从CIL深处窥探值类型与引用类型的生死较量,一场关于速度与空间的激情大戏!"
【8月更文挑战第16天】在.NET框架中,通过CIL(公共中间语言)可以深入了解值类型与引用类型的内存分配机制。值类型如`int`和`double`直接在方法调用堆栈上分配,访问迅速,生命周期随栈帧销毁而结束。引用类型如`string`在托管堆上分配,堆栈上仅存储引用,CLR负责垃圾回收,确保高效且自动化的内存管理。
45 6
|
1月前
|
算法 安全 UED
探索操作系统的内核空间:虚拟内存管理
【7月更文挑战第50天】 在现代操作系统中,虚拟内存管理是核心功能之一,它允许操作系统高效地使用物理内存,并为应用程序提供独立的地址空间。本文将深入探讨操作系统虚拟内存管理的机制,包括分页、分段以及内存交换等关键技术,并分析它们如何共同作用以实现内存的有效管理和保护。通过理解这些原理,读者可以更好地把握操作系统的内部工作原理及其对应用程序性能的影响。
|
30天前
|
存储 程序员 编译器
c++学习笔记08 内存分区、new和delete的用法
C++内存管理的学习笔记08,介绍了内存分区的概念,包括代码区、全局区、堆区和栈区,以及如何在堆区使用`new`和`delete`进行内存分配和释放。
37 0
|
1月前
|
C语言
【C语言篇】字符和字符串以及内存函数详细介绍与模拟实现(下篇)
perror函数打印完参数部分的字符串后,再打印⼀个冒号和⼀个空格,再打印错误信息。
|
1月前
|
存储 安全 编译器
【C语言篇】字符和字符串以及内存函数的详细介绍与模拟实现(上篇)
当然可以用scanf和printf输入输出,这里在之前【C语言篇】scanf和printf万字超详细介绍(基本加拓展用法)已经讲过了,这里就不再赘述,主要介绍只针对字符的函数.
|
1月前
【C初阶】内存函数:memcpy+memmove+memset+memcmp
【C初阶】内存函数:memcpy+memmove+memset+memcmp
|
1月前
|
存储 编译器 C语言
【C语言篇】数据在内存中的存储(超详细)
浮点数就采⽤下⾯的规则表⽰,即指数E的真实值加上127(或1023),再将有效数字M去掉整数部分的1。
|
2月前
|
存储 分布式计算 Hadoop
HadoopCPU、内存、存储限制
【7月更文挑战第13天】
187 14
|
21天前
|
存储 监控 Docker
如何限制docker使用的cpu,内存,存储
如何限制docker使用的cpu,内存,存储

热门文章

最新文章