C++之Max

背景

想学习数据结构,这是看的课程的习题,讲课老师用的是类C语言,具体的实现还是得自己来。

准备工作

  1. 开发工具Microsoft Visual Studio(VS)建立一个空白的C++控制台项目

  2. 选择项目的存储路径

  3. 成功建立

我在 Microsoft Visual Studio中用C++写的第一个代码

具体代码

#include <iostream>
#define N 10
void Output(int* a);
void Input(int* a);
int Max(int a[]);
int getRandom(int min, int max);
void getRandom(int b[]);
​
// 用数组做函数的参数,求10个整数的最大数
/*1. 先定义一个包含10个整数的数组1.1 写死(不灵活)1.2 可自行输入(手输,累,还容易输成其他类型的数据【需要对输入的数据类型进行卡控】)1.3 自动生成数据(棒,写代码累,但只需要写一次,可用千千万万次)2. 比较10个整数,输出最大的那个
*/
​
int main()
{int a[10];getRandom(a); //Input(a);Output(a);int m = Max(a);std::cout << "the Max number is :" << m;
}
​
​
/// <summary>
/// 為數組a賦初值
/// </summary>
/// <param name="a"></param>
void getRandom(int b[]) {for (int i = 0; i < N; i++)b[i] = getRandom(0, 100);
}
​
/// <summary>
/// 獲取隨機數
/// </summary>
/// <param name="min"></param>
/// <param name="max"></param>
/// <returns></returns>
int getRandom(int min, int max) {return (rand() % (max - min + 1) + min);
}
​
​
void Input(int* b) {for (int i = 0; i < N; i++)std::cin >> b[i];
}
​
int Max(int b[])
{int m = 0;for (int i = 0; i < N - 1; i++)if (b[i+1] > m) m = b[i + 1];//for (int i = 1; i < N ; i++)//  if (b[i] > m)//      m = b[i];return m;
}
​
void Output(int* b) {for (int i = 0; i < N; i++)std::cout << b[i] << "\t";std::cout << "\n";
}

VS快捷键

Ctrl+K+C =>// 屏蔽语句
​
Ctrl+K+U =>// 取消屏蔽

遇到的问题

  • 代码运行不起来

    • 函数在有调用的情况下,比如Input(a); 没有写函数声明

      ,导致系统运行不起来

    • 快捷生成函数声明=>选中点击右键=>

  • 输出报错=>调试错误 由于函数的调用约定造成的错误

    • 报错语句=>std::cout << "the Maxium number is :" + Max(a);

    • 报错内容=>ot properly saved across a function call. This is usually a result of calling a function declared with one calling convention with a function pointer declared with a different calling convention.调试错误 由于函数的调用约定造成的错误

    • 报错原因=>看了下老师的类C语句,发现我的输出语句用的+,之前C#写习惯了,添加输出变量,直接加在后面,+改成<<就好

    • 调试错误 由于函数的调用约定造成的错误 - 乘舟凉 - 博客园 (cnblogs.com)=>虽然好像对我这个报错没啥用

  • 生成随机数

    • C++产生随机数的几种方法_c++随机数生成-CSDN博客=>return (rand() % (max - min + 1) + min);生成的随机数有点固定,第一次的数字永远是那几个,但如果是在循环里的话,基本会不一样,但要是每次重开程式,数据基本是固定的,不算真正的随机

    • 用了文中其他的随机函数,需头部添加#include <random>

      std::random_device rd;
      std::default_random_engine eng(rd());
      std::uniform_int_distribution<size_t> dis(0, 100);
      int res = dis(eng);
      return res; 

      我的输出最大值居然不对了!!!==>乌龙了,我的找最大数的函数写错了,比较的是b[i+1]>b[i]==>改成b[i+1]>m就可

记录要点

  • 数组是基于指针实现的;
  • 数组名代表首元素的地址,指针可以存储地址;
  • 访问首地址a[0];*a;*(a+0);
  • 参数(int * b)和(int b[])都可以传入数组
  • malloc 创造动态数组,开辟失败则返回空指针

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/176992.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

OSG路径动画:osg::AnimationPath示例

一、效果 飞船绕地球飞行 二、源码 // osg_AnimationPath.cpp : 此文件包含 "main" 函数。程序执行将在此处开始并结束。 // #include <windows.h> #include <iostream> #include <osgViewer/Viewer>

Elasticsearch的配置学习笔记

文/朱季谦 Elasticsearch是一个基于Lucene的搜索服务器。它提供一个分布式多用户能力的全文搜索引擎&#xff0c;基于RESTful web接口&#xff0c;Elasticsearch是用Java语言开发的。 关于Elasticsearch系列笔记&#xff0c;主要从Elasticsearch的配置、核心组件、架构设计、使…

navicat导入已有sql表过程

已知我有一个外部的sql表&#xff0c;如图&#xff1a; 想要将其导入navicat并运行。 看一下我的navicat&#xff0c; navicat里已有的数据库并没有library&#xff0c;所以需要建立一个同名的library数据库来存储library.sql文件。 具体步骤如下&#xff1a; 在“本地连接”…

pdf增强插件 Enfocus PitStop Pro 2022 mac中文版功能介绍

Enfocus PitStop Pro mac是一款 Acrobat 插件&#xff0c;主要用于 PDF 预检和编辑。这个软件可以帮助用户检查和修复 PDF 文件中的错误&#xff0c;例如字体问题、颜色设置、图像分辨率等。同时&#xff0c;Enfocus PitStop Pro 还提供了丰富的编辑工具&#xff0c;可以让用户…

CNVD-2021-27648:锐捷RG-UAC统一上网行为管理与审计系统信息泄露漏洞复现

文章目录 锐捷RG-UAC统一上网行为管理与审计系统信息泄露&#xff08;CNVD-2021-27648&#xff09;漏洞复现0x01 前言0x02 漏洞描述0x03 影响版本0x04 漏洞环境0x05 漏洞复现1.访问漏洞环境2.复现 0x06 修复建议 锐捷RG-UAC统一上网行为管理与审计系统信息泄露&#xff08;CNVD…

Linux组调度

为什么引入组调度可以参考这篇文章的讨论。核心原因是基础的调度算法都是基于任务的&#xff0c;如果用户A有10个任务&#xff0c;用户B只有1个任务&#xff0c;假设这些任务的优先级都相同&#xff0c;那么用户A得到的CPU时间将是用户B的10倍&#xff0c;这样从任务的角度看虽…

【Linux】进程替换|exec系列函数

文章目录 一、看一看单进程版的进程替换二、进程替换的原理三、多进程版——验证各种程序替换接口exec系列函数execlexeclpexecvexecvp tipsexecleexecve 四、总结 一、看一看单进程版的进程替换 #include<stdio.h> #include<unistd.h> #include<stdlib.h>i…

Hive函数

1. Hive 内置运算符 整体上&#xff0c;Hive 支持的运算符可以分为三大类&#xff1a;关系运算、算术运算、逻辑运算。 官方参考文档&#xff1a;LanguageManual UDF - Apache Hive - Apache Software Foundation 也可以使用下述方式查看运算符的使用方式&#xff1a; -- 显…

短视频矩阵seo系统源码搭建----技术定制化开发

一、需要遵循一下技术开发步骤&#xff1a; 1. 确定需求和功能&#xff1a;明确系统的主要目标和需要实现的功能&#xff0c;包括关键词研究、短视频制作、外链建设、数据分析、账号设置优化等方面。 2. 设计系统架构&#xff1a;根据需求和功能确定系统的架构&#xff0c;包…

openGauss Summit 2023 | Call for Sponsor、Speaker、Demo

数据库作为千行万业数据的基石&#xff0c;也是推动数字经济发展的核心。随着数字经济的蓬勃发展&#xff0c;数据库将迎来更加广阔的应用场景和更加迫切的需求。openGauss 社区旨在汇聚产、学、研、用多方力量&#xff0c;聚焦基础软件核心能力的构建&#xff0c;引领国内数据…

LeetCode - 232.用栈实现队列 225.用队列模拟实现栈 (C语言,配图)

目录 232.用栈实现队列 225.用队列模拟实现栈 注&#xff1a;本文是基于C语言实现的代码&#xff0c;所以栈和队列是在力扣上制造实现的&#xff0c;如果你使用C等语言&#xff0c;可以忽略前面相当大部分的代码。 在栈模拟实现栈和队列之前&#xff0c;我们先来复习一下栈和…

2023年数维杯国际大学生数学建模挑战赛

当大家面临着复杂的数学建模问题时&#xff0c;你是否曾经感到茫然无措&#xff1f;作为2022年美国大学生数学建模比赛的O奖得主&#xff0c;我为大家提供了一套优秀的解题思路&#xff0c;让你轻松应对各种难题。 cs数模团队在数维杯前为大家提供了许多资料的内容呀&#xff0…