C++基础-编程练习题和答案

文章目录

  • 一、查找插入有序数组的位置
  • 二、最高分
  • 三、不与最大数相同的数字之和
  • 四、最大值和最小值的差
  • 五、数字放大
  • 六、多余的数
  • 七、数字接力
  • 八、幸运大抽奖

一、查找插入有序数组的位置

【试题描述】
给你 m 个已经从小到大排好序的整数, 输入一个数 x, 输出 x 插入的位置,保证 x 插入后
的 m+1 数还是有序的。
【输入要求】
第一行一个整数 m, 表示数的个数 ( m <= 100 )
第二行 m 个整数 ( 这些数在 0-999999 范围内 )
第三行为要查找的数 x
【输出要求】
x 的位置
【输入样例】
10
9 19 20 23 56 78 90 180 190 230
35
【输出样例】
5

#include <bits/stdc++.h>
using namespace std;/**给你 m 个已经从小到大排好序的整数, 输入一个数 x, 输出 x 插入的位置,保证 x 插入后的 m+1 数还是有序的。*/
int main() {  int m;  cin >> m; // 输入数的个数  int nums[m];  for (int i = 0; i < m; ++i) {  cin >> nums[i]; // 输入m个整数  }  int x;  cin >> x; // 输入要查找的数x  //插入的位置int p;// 查找并输出x的插入位置  for (int i = 0; i < m; ++i) {  if(nums[i]>=x){p=i+1;break;}}  // 退出循环时,p即为x的插入位置  cout<<p<<endl;return 0;  
}

二、最高分

【试题描述】
全班 n 个同学的成绩需要按学号读入, 请找出班级最高分, 并找出最高分的得主。 (假设
无重复成绩)
【输入要求】
两行, 第一行为一个正整数 n, 第二行为 n 个实数, 每个实数之间用一个空格分隔。
【输出要求】
NO (学号) : (成绩) 保留小数点后一位小数。
【输入样例】
5
92 97.5 93 87 89
【输出样例】
NO2:97.5

#include <bits/stdc++.h>  using namespace std;  
/**全班 n 个同学的成绩需要按学号读入, 请找出班级最高分, 并找出最高分的得主。 (假设无重复成绩)*/
int main() {  int n;  cin >> n; // 读取学生数量  double scores[n];double maxScore = 0; // 初始化最高分0int maxScoreIndex = 0; // 最高分对应的学号索引  for (int i = 0; i < n; ++i) {  cin >> scores[i]; // 读取成绩  }  for (int i = 0; i < n; ++i) {  if (scores[i] > maxScore) {  maxScore = scores[i]; // 更新最高分  maxScoreIndex = i; // 更新最高分对应的学号索引  }  }  // 输出最高分及其学号  cout << "NO" << maxScoreIndex + 1 << ":" << fixed << setprecision(1) << maxScore << endl;  return 0;  
}

三、不与最大数相同的数字之和

【试题描述】
求出一个整数数列中不与最大数相同的数字之和。
【输入要求】
输入分为两行:
第一行为 n, (n ≤ 100)
第二行为 n 个整数。
【输出要求】
输出为 n 个数中不与最大数相同的其余数字之和。
【输入样例】
3
1 2 3
【输出样例】
3

#include <bits/stdc++.h>  
using namespace std;
/**求出一个整数数列中不与最大数相同的数字之和。*/int main() {  int n;  cin >> n; // 输入整数n  //定义n个元素的数组int m[n];  for (int i = 0; i < n; i++) {  cin >> m[i]; // 输入n个整数  }  // 找到数组中的最大数  int max=m[0];for(int i=0;i<n;i++){if(m[i]>max){max=m[i];}}int sum = 0;  // 计算所有不与最大数相同的数字之和  for (int i = 0; i < n; i++) {   if (m[i] != max) {  sum = sum+m[i];  }  }  cout << sum << endl; // 输出结果  return 0;  
}

四、最大值和最小值的差

【试题描述】
输出一个整数序列中最大的数和最小的数的差。
【输入要求】
第一行为 n, 表示整数个数, 整数个数不会大于 10000;
第二行为 n 个整数, 每个整数的绝对值不会大于 10000。
【输出要求】
输出 n 给数中最大值和最小值的差。
【输入样例】
5
2 5 7 4 2
【输出样例】
5

#include <bits/stdc++.h>
using namespace std;
/**最大值和最小值的差*/int main() {  int n;  cin >> n; // 输入整数个数  int numbers[n];  for (int i = 0; i < n; ++i) {  cin >> numbers[i]; // 输入整数序列  }  // 初始化最大值为,最小值int max_num = numbers[0];  int min_num = numbers[0];  // 遍历数组找到最大值和最小值  for(int i=0;i<n;i++){max_num = max(max_num, numbers[i]);  min_num = min(min_num, numbers[i]); }// 计算最大值和最小值的差  int diff = max_num - min_num;  cout << diff << endl; // 输出结果  return 0;  
}

五、数字放大

【试题描述】
给定一些整数以及放大倍数 x, 将每个整数放大 x 倍后输出。
【输入要求】
包含三行:
第一行为 n, 表示整数的个数
第二行为 n 个给定的整数(不超过整形范围)
第三行为整数 x, 表示放大的倍数
【输出要求】
n 个整数, 为原数列放大之后的数列, 两数之间以一个空格分开。
【输入样例】
3
1 5 7
2
【输出样例】
2 10 14

#include<bits/stdc++.h>
using namespace std;
/**给定一些整数以及放大倍数 x, 将每个整数放大 x 倍后输出。*/int main() {  int n;  cin >> n; // 输入整数的个数  int numbers[n];  for (int i = 0; i < n; ++i) {  cin >> numbers[i]; // 输入给定的整数  }  int x;  cin >> x; // 输入放大的倍数  // 放大每个整数并输出  for (int i = 0; i < n; ++i) {  cout << numbers[i] * x  << " ";  }  return 0;  
}

六、多余的数

【试题描述】
小 A 同学在完成一个数学题: 求给定的 n 个整数的和。 小 A 同学在求完之后发现和参考答案
对不上, 检查后发现在求和过程中多计算了一个数, 其他过程没问题。 现给出小 A 计算用的
n+1 个数, 以及正确的参考答案, 请算出小 A 同学多计算的那一个数。
【输入要求】
第一行 n 的值
第二行 n+1 个正整数, 每个数小于等于 1000000
第三行一个整数 x, 表示参考答案
【输出要求】
一个整数, 表示多计算的那一个数。
【输入样例】
10
2 4 6 8 1 3 5 7 9 5 11
54
【输出样例】
7
【提示】
样例中原有的 10 个数为 2 4 6 8 1 3 5 9 5 11, 和为 54, 多余的数为 7。

#include<bits/stdc++.h>
using namespace std;
/**小 A 同学在完成一个数学题: 求给定的 n 个整数的和。 小 A 同学在求完之后发现和参考答案对不上, 检查后发现在求和过程中多计算了一个数, 其他过程没问题。 现给出小 A 计算用的n+1 个数, 以及正确的参考答案, 请算出小 A 同学多计算的那一个数。*/int main() {  int n;  cin >> n; // 输入整数的个数  int m[n + 1]; // 创建大小为n+1的数组来存储n+1个数  for (int i = 0; i < n + 1; ++i) {  cin >> m[i]; // 输入n+1个整数  }  int correct;  cin >> correct; // 输入参考答案  // 计算所有n+1个数的和  int sumOfAll = 0;  for (int i=0;i<n+1;++i) {  sumOfAll += m[i];  }  // 计算多出的那个数  int extraNum = sumOfAll - correct;  cout << extraNum << endl; // 输出多出的那个数  return 0;  
}

七、数字接力

【试题描述】
奶牛们在玩一个数字游戏, 它们从一个整数开始, 比如: 6593。 将这个整数中的各位数
字全部取出, 将他们相乘, 得到一个新的整数, 上面的例子就是 6593=810, 然后继续做
下去, 8
10=0 得到了一个个位数 0。
帮助奶牛完成这个游戏, 读入一个数并计算出有游戏得到一个个位数的过程。
【输入要求】
一个整数 N(10<=n<= 2,000,000,000)。
【输出要求】
在单独的一行中按顺序输出游戏过程中产生的每一个数直到一个个位数结束。 相邻两数
之间要求严格用一个空格隔开, 最后一个数之后不能有空格。
【输入样例】
98886
【输出样例】
98886 27648 2688 768 336 54 20 0

#include<bits/stdc++.h>
using namespace std;
/**奶牛们在玩一个数字游戏,它们从一个整数开始,比如: 6593。将这个整数中的各位数字全部取出,将他们相乘,得到一个新的整数,上面的例子就是 6*5*9*3=810,然后继续做下去,8*1*0*=0 得到了一个个位数 0。帮助奶牛完成这个游戏,读入一个数并计算出有游戏得到一个个位数的过程。*/
int main() {  int n;  cin >> n; // 输入整数  int current = n;  //输出ncout<< n << " ";//当得到一个个位数时停止while  (current >9){int product = 1;  //取出每个位上的数相乘while (current > 0) {  product =product* (current % 10); // 取出最低位数字并相乘  current = current/10;           // 去掉最低位数字  }current=product;// 输出游戏过程中产生的每一个数 cout<< product ;if(product>9){//相邻两数之间要求严格用一个空格隔开。cout << " ";	}}  return 0;  
}

八、幸运大抽奖

【试题描述】
淘淘参加游乐园的幸运大抽奖活动。 活动规则如下: 通过参加 5 项游乐活动, 获得相应积分,
积分和的各位数字之和若为回文数, 则可到领奖处领取奖品一份。 请编程完成判断。
【输入要求】
输入 5 个整数
【输出要求】
Congratulations!或者 Sorry!
【输入样例】
51 26 3 21 8
【输出样例】
Sorry!
【解题提示】
回文数即数字顺着和反着是同一个数。 如 121

#include<bits/stdc++.h>
using namespace std;
/**淘淘参加游乐园的幸运大抽奖活动。 活动规则如下: 通过参加 5 项游乐活动, 获得相应积分,积分和的各位数字之和若为回文数, 则可到领奖处领取奖品一份。 请编程完成判断。输入20 21 10 11 12输出Congratulations!*/int main() {  //定义积分数组int scores[5];  // 读取5个整数  for (int i = 0; i < 5; ++i) {  cin >> scores[i];  }  // 计算5个整数的和  109int total = 0;  for (int i=0;i<5;i++) {  total += scores[i];  }  // 计算和的各位数之和   9+0+1=10int sum = 0;  while (total > 0) {  sum = sum + total % 10;  //取最低位数字total /= 10;  // 去掉最低位数字}  int s = sum; // 将sum的各位数反过来  0+1=1int reversed = 0;  while (s > 0) {  //乘以10+对10取余数 得到回文数字reversed = reversed * 10 + s % 10;  s /= 10;  }   // 判断各位数之和是否是回文数  1 不等于10	if (sum == reversed) {  cout << "Congratulations!" << endl;  } else {  cout << "Sorry!" << endl;  }  return 0;  
}

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

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

相关文章

Duplicate File Finder Pro for Mac激活版:重复文件清理软件

在繁杂的文件管理中&#xff0c;你是否曾为重复文件而烦恼&#xff1f;Duplicate File Finder Pro for Mac&#xff0c;正是你不可或缺的得力助手。这款专业级工具&#xff0c;能够迅速扫描并定位Mac系统中的重复文件&#xff0c;让你的存储空间恢复清爽。 通过强大的算法支持&…

[C/C++] -- 代理模式

代理模式是一种结构型设计模式&#xff0c;允许一个对象&#xff08;代理&#xff09;控制另一个对象的访问。代理对象通常充当客户端和实际目标对象之间的中间人&#xff0c;从而控制对目标对象的访问&#xff0c;可以在访问前后进行一些额外的处理。 代理模式的优点包括&…

《铁路出行更便捷:火车票预定审批系统的设计与应用》

在现代化的铁路交通管理中&#xff0c;火车票预定审批系统扮演着至关重要的角色。它不仅能够有效管理员工出差、培训等需要乘坐火车的行程&#xff0c;还能够提高审批效率&#xff0c;减少人力成本&#xff0c;确保出行安全。本文将探讨火车票预定审批系统的设计原则和应用场景…

图片压缩和尺寸调节工具@图像压缩@分辨率调节@降低图片文件体积和磁盘占用

文章目录 abstract降低图片文件大小的方式相关原理 跨平台免费的压缩工具离线运行的软件在线工具&#x1f47a;windows 系统上的压缩方法windows 照片程序(photo)powertoys image-resizer(分辨率/尺寸调整) windows mspaint(画图工具调整分辨率) abstract 提到图片压缩时&#…

一款支持几分钟视频生成,免费无限制AI视频生成网站

前言 AI可以生成原创中视频了&#xff01; 不是4秒&#xff0c;而是最长达6分钟&#xff0c;官方名为白日梦&#xff0c;将白日梦变成现实&#xff01; 他不是简单的文生图/图生视频 而是将文生图、图生视频、配音字幕、后期剪辑等&#xff0c;打包封装成一条AI视频生产工作…

Axure PR 10 下拉三级菜单设计图

在线预览地址&#xff1a;Untitled Document 程序员必备资源网站&#xff1a;天梦星服务平台 (tmxkj.top) 需要源码设计图联系我wx:19948765606,3块钱拿走

Maven+Junit5 + Allure +Jenkins 搭建 UI 自动化测试实战

文章目录 效果展示Junit 5Junit 5 介绍Junit 5 与 Junit 4 对比PageFactory 模式编写自动化代码公共方法提取测试用例参数化Jenkins 搭建及配置参数化执行生成 Allure 报告Maven 常用命令介绍POM 文件效果展示 本 chat 介绍 UI 自动化测试框架的搭建: 运用 page factory 模式…

文章解读与仿真程序复现思路——电力自动化设备EI\CSCD\北大核心《基于V2G潜力模糊评估与移动储能协调调度的灾后供电恢复策略》

本专栏栏目提供文章与程序复现思路&#xff0c;具体已有的论文与论文源程序可翻阅本博主免费的专栏栏目《论文与完整程序》 论文与完整源程序_电网论文源程序的博客-CSDN博客https://blog.csdn.net/liang674027206/category_12531414.html 电网论文源程序-CSDN博客电网论文源…

第12章 软件测试基础(第三部分)测试类型、测试工具

七、测试类型&#xff08;按工程阶段划分&#xff09; 单集系确收 &#xff08;一&#xff09;单元测试 1、单元测试/模块测试 单元就是软件中最小单位&#xff08;或模块&#xff09;。可以是一个函数、一个过程、一个类。主要依据是模块的详细设计文档。价值在于尽早发现…

spring模块(六)spring监听器(1)ApplicationListener

一、介绍 1、简介 当某个事件触发的时候&#xff0c;就会执行的方法块。 当然&#xff0c;springboot很贴心地提供了一个 EventListener 注解来实现监听。 2、源码&#xff1a; package org.springframework.context;import java.util.EventListener; import java.util.fu…

游戏理解入门:Rust+Bracket开发一个小游戏

1. Game loop 使用game loop可以使得游戏运行更加流畅和顺滑&#xff0c;它可以&#xff1a; 初始化窗口、图形和其他资源&#xff1b;每当屏幕刷新他都会运行(通常是每秒30,60 )&#xff1b;每次通过循环&#xff0c;他都会调用游戏的tick()函数。 大致的原理流程如下&…

如何查看公网IP开放端口?

在计算机网络中&#xff0c;公网IP是指能够直接访问互联网的IP地址&#xff0c;而开放端口则是指外部网络可以访问的服务端口。查看公网IP开放端口可以帮助我们了解当前网络环境中哪些服务可以被外部网络访问&#xff0c;对于网络安全和远程连接非常重要。 天联组网 天联组网是…

2024蓝桥杯网络安全部分赛题wp

爬虫协议 题目给了提示访问robots.txt 会出三个目录 访问最后一个 点进去就flag{22560c15-577c-4c8b-9944-815473758bad} packet 下载附件&#xff0c;这个是流量包 放wireshark流量分析 搜http协议 发现有cat flag命令&#xff0c;直接看他返回的流量 最后base64解码即可…

Linux-笔记 i2c-tools

1、i2c-tools介绍 1、在日常linux开发中&#xff0c;有时候需要确认i2c硬件是否正常连接&#xff0c;设备是否正常工作&#xff0c;设备的地址是多少等等&#xff0c;这里我们就需要使用一个用于测试I2C总线的工具——i2c-tools&#xff0c;i2c-tools原理是通过操作/dev 路径 …

存储大作战:探索Local Storage与Session Storage的奥秘

欢迎来到我的博客&#xff0c;代码的世界里&#xff0c;每一行都是一个故事 存储大作战&#xff1a;探索Local Storage与Session Storage的奥秘 前言Local Storage与Session Storage简介数据存储生命周期容量限制安全性 前言 在Web的世界里&#xff0c;数据就像是一群流浪者&a…

TypeScript学习日志-第二十三天(装饰器Decorator)

装饰器Decorator 一、类装饰器 ClassDecorator 其中返回的 target 是 Http 的构造函数&#xff0c;有了构造函数就不会去破坏其自身原有的结构&#xff0c;当我们 Http 里面有多个属性或者方法的&#xff0c;当是我们不想看或者改变它&#xff0c;这时候可以在构造函数中增加即…

Ubuntu18.04 安装 anconda

anaconda官网 bash Anaconda3-2021.11-Linux-x86_64.sh一直回车&#xff0c;输入yes 选择安装目录 是否希望更新shell配置文件以自动初始化conda

组合数学汇总

阶乘、排列、组合 阶乘 x ! Π i : 1 x i x! \Pi_{i:1}^xi x!Πi:1x​i 。特殊情况0的阶乘是1。 排列 排列 P n m P_n^m Pnm​&#xff0c;从n个不同元素中取出m&#xff08;m≤n&#xff09;个元素&#xff0c;按照一定的顺序排成一列。第一个元素有n种选择&#xff0c;第…

AR人脸美妆SDK解决方案,让妆容更加贴合个人风格

美妆行业正迎来前所未有的变革&#xff0c;为满足企业对高效、精准、创新的美妆技术需求&#xff0c;美摄科技倾力打造了一款企业级AR人脸美妆SDK解决方案&#xff0c;为企业打开美妆领域的新世界大门。 革命性的人脸美妆技术 美摄科技的AR人脸美妆SDK解决方案&#xff0c;不…

IDEA设置 | 个性化设置

文章目录 IDEA设置总结IDEA自动生成序列化ID IDEA设置总结 本篇博客将专注于整理IDEA新UI界面的相关设置 IDEA自动生成序列化ID CtrlAltS快捷键打开设置界面 选择Editor→Inspections→JVM languages→Test frameworks&#xff0c;勾选上Serializable class without serialVe…