信息学奥赛一本通C++ - 第二章 - 第四节 数据输入输出

本文主要是介绍信息学奥赛一本通C++ - 第二章 - 第四节 数据输入输出,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

2069:【例2.12 】糖果游戏

题目描述

在一个幼儿园游戏中,5个小朋友编号为1、2、3、4、5围坐一圈,每个小朋友有一定数量的糖果。游戏开始时,每个小朋友将自己的糖果分成三份,多余的立即吃掉,然后将两份糖果分别给左右两边的小朋友。一轮分糖果后,求每个小朋友手上的糖果数量。

解题思路
  1. 读取输入:获取每个小朋友初始的糖果数。
  2. 计算分糖果:每个小朋友将糖果均分为三份,多余的糖果吃掉,自己保留一份,其余两份分给两边的小朋友。
  3. 汇总结果:计算一轮游戏后,每个小朋友手上的糖果总数。
  4. 输出结果:按要求格式输出每个小朋友的糖果数。
知识点讲解
代码实现
#include <iostream>
#include <iomanip>
using namespace std;
int main()
{int buf[5];for(int i = 0; i < 5; i++){cin >> buf[i];} for(int i = 0; i < 5; i++){buf[i] -= buf[i] % 3;//吃掉部分。 buf[i] /= 3;//自己留一份 buf[(i + 4) % 5] += buf[i];//给左边一份 buf[(i + 1) % 5] += buf[i];//给右边一份 }for(int i = 0; i < 5; i++){cout << setw(5) << buf[i];}return 0;
}
代码解析
  • 初始糖果数存储在数组 buf 中。
  • 吃掉的糖果为buf[i] % 3,用于分配的糖果为buf[i] -= buf[i] % 3
  • 每个小朋友分配后的糖果存储在buf数组中。
  • 输出时使用 setw(5) 保证输出格式为每个数字占据5位宽度,与题目要求一致。

1024:保留3位小数的浮点数

题目描述

输入一个单精度浮点数,输出该浮点数保留3位小数的结果。

解题思路
  1. 读取输入:从输入中读取一个浮点数。
  2. 格式化输出:使用C++标准库的功能保留3位小数后输出该浮点数。
代码实现
#include <iostream>
#include <iomanip>  // 包含用于输出格式化的库
using namespace std;int main() {float value;cin >> value;  // 从标准输入读取一个单精度浮点数// 设置输出的浮点数精度为3位小数cout << fixed << setprecision(3) << value << endl;return 0;
}
代码解析
  • 头文件:包含<iostream>用于基本输入输出操作,<iomanip>用于设置输出格式。
  • 输入操作:使用cin读取一个单精度浮点数。
  • 输出操作
    • cout << fixed:设置cout以固定点表示法输出浮点数。
    • setprecision(3):设置浮点数输出时保留3位小数。
    • 最终输出的浮点数value将保留3位小数。

这个程序能有效地读取一个浮点数并输出它保留3位小数的结果,符合题目要求。

1025:保留12位小数的浮点数

题目描述

读入一个双精度浮点数,并输出该浮点数保留12位小数的结果。

解题思路
  1. 读取输入:从标准输入读取一个双精度浮点数。
  2. 格式化输出:设置输出浮点数时保留12位小数,并输出。
代码实现
#include <iostream>
#include <iomanip>  // 包含用于格式化输出的库
using namespace std;int main() {double value;cin >> value;  // 从标准输入读取一个双精度浮点数// 设置输出的浮点数精度为12位小数cout << fixed << setprecision(12) << value << endl;return 0;
}
代码解析
  • 头文件说明
    • <iostream> 用于标准输入输出操作。
    • <iomanip> 提供了设置输出格式的功能,如 setprecision,用于设置浮点数输出的小数位数。
  • 输入处理:通过 cin 读取一个双精度浮点数。
  • 输出格式化
    • 使用 cout << fixed 来确保浮点数以固定点方式输出。
    • setprecision(12) 设置后续浮点数输出保留12位小数。

这个程序能够有效地处理和格式化双精度浮点数的输入和输出,确保输出的数值精确到小数点后12位。

1026:空格分隔输出

题目描述

读入一个字符、一个整数、一个单精度浮点数和一个双精度浮点数,然后按顺序输出它们,并要求在他们之间用一个空格分隔。输出浮点数时保留6位小数。

解题思路
  1. 读取输入:从标准输入依次读取一个字符、一个整数、一个单精度浮点数和一个双精度浮点数。
  2. 格式化输出:将这些值按顺序输出,每个值之间用一个空格分隔,并确保浮点数输出保留6位小数。
代码实现
#include <iostream>
#include <iomanip>  // 包含设置输出格式的库
using namespace std;int main() {char ch;int integer;float singleFloat;double doubleFloat;// 读取输入cin >> ch >> integer >> singleFloat >> doubleFloat;// 设置浮点数输出精度为6位小数cout << fixed << setprecision(6);// 输出结果,各数据项之间使用空格分隔cout << ch << " " << integer << " " << singleFloat << " " << doubleFloat << endl;return 0;
}
代码解析
  • 头文件说明
    • <iostream> 用于标准输入输出。
    • <iomanip> 提供了格式化输出的功能,例如 setprecision 用于设置浮点数输出的小数位数。
  • 输入处理:通过 cin 依次读取字符、整数、单精度浮点数和双精度浮点数。
  • 输出格式化
    • 使用 cout << fixed 确保浮点数以固定点格式输出。
    • setprecision(6) 设置浮点数输出时保留6位小数。
    • 输出时使用空格 (" ") 分隔各个数据项,确保格式清晰易读。

此程序通过精确控制输出格式,能够满足题目要求,确保数据的准确和美观展示。

1027:输出浮点数

题目描述

读入一个双精度浮点数,并依次按照不同的格式输出。首先以默认的浮点数格式(通常保留六位小数)输出,接着输出保留5位小数的格式,然后以科学计数法输出,并最后使用%g格式输出,这种格式基于数值大小和精度自动选择浮点数或科学计数法的显示方式。

解题思路
  1. 读取输入:从标准输入接收一个双精度浮点数。
  2. 格式化输出
    • 第一行:使用默认的浮点数格式。
    • 第二行:保留5位小数。
    • 第三行:使用科学计数法格式。
    • 第四行:使用%g格式,根据数值自动选择显示方式。
代码实现
#include <iostream>
#include <iomanip>
using namespace std;int main() {double number;cin >> number;  // 从标准输入读取一个双精度浮点数// 第一行:使用默认的浮点数格式(通常是保留6位小数)cout << fixed << setprecision(6) << number << endl;// 第二行:保留5位小数的浮点数格式cout << fixed << setprecision(5) << number << endl;// 第三行:使用科学计数法格式cout << scientific << setprecision(6) << number << endl;// 第四行:使用%g格式输出,自动选择最合适的表示方法cout.unsetf(ios_base::floatfield); // 清除fixed或scientific状态cout << setprecision(6) << number << endl;return 0;
}
代码解析
  • 使用 cout << fixedsetprecision(6) 首次输出浮点数,默认保留六位小数。
  • 切换到 fixed << setprecision(5) 保留五位小数输出。
  • 使用 cout << scientific 转为科学计数法,仍然保留六位小数。
  • 最后,通过 cout.unsetf(ios_base::floatfield); 清除浮点格式设置,并使用 setprecision(6) 通过 %g 自动选择格式输出。

这段程序能够准确地按照要求格式输出双精度浮点数,保证输出精度与美观。

1028:字符菱形

题目描述

根据给定的字符,构造一个对角线长为5个字符的菱形,该菱形由输入字符构成。

解题思路

要构建一个由输入字符组成的菱形,可以通过输出多行字符串,每行根据所需字符数和位置适当地加入空格来实现。具体到对角线长度为5的菱形,我们可以按照以下模式构建:

  • 第一行:2个空格,1个字符
  • 第二行:1个空格,3个字符
  • 第三行:5个字符
  • 第四行:1个空格,3个字符
  • 第五行:2个空格,1个字符
代码实现
#include <iostream>
#include <iomanip>
using namespace std;int main() {char ch;cin >> ch;  // 从标准输入读取一个字符// 使用标准输出流cout,输出字符菱形的五行cout << setw(3) << right << ch << endl; // 第一行:居中,占位3,右侧输出字符cout << setw(2) << right << ch << ch << ch << endl; // 第二行:占位2,输出3个字符cout << ch << ch << ch << ch << ch << endl; // 第三行:输出5个字符cout << setw(2) << right << ch << ch << ch << endl; // 第四行:占位2,输出3个字符cout << setw(3) << right << ch << endl; // 第五行:居中,占位3,右侧输出字符return 0;
}
代码解析
  • 使用 cin 读取一个字符。
  • 使用 setwright 控制字符输出的位置,setw(n) 设置下一个输出字段的最小宽度为n。当用于字符输出时,它主要是用来添加前置空格,确保字符在适当的位置输出。
  • 输出的每行都通过 cout 控制字符的位置和数量,以形成菱形的上半部和下半部对称性。
  • 输出的菱形有5行,每行字符的数量和空格数量经过精确计算,以保持菱形的对称性和整洁。

这段代码能够准确地按照要求输出一个使用指定字符组成的菱形,每行字符的位置和数量都精确控制以形成完美的菱形图案。

这篇关于信息学奥赛一本通C++ - 第二章 - 第四节 数据输入输出的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/912143

相关文章

Python使用vllm处理多模态数据的预处理技巧

《Python使用vllm处理多模态数据的预处理技巧》本文深入探讨了在Python环境下使用vLLM处理多模态数据的预处理技巧,我们将从基础概念出发,详细讲解文本、图像、音频等多模态数据的预处理方法,... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

从入门到精通C++11 <chrono> 库特性

《从入门到精通C++11<chrono>库特性》chrono库是C++11中一个非常强大和实用的库,它为时间处理提供了丰富的功能和类型安全的接口,通过本文的介绍,我们了解了chrono库的基本概念... 目录一、引言1.1 为什么需要<chrono>库1.2<chrono>库的基本概念二、时间段(Durat

C++20管道运算符的实现示例

《C++20管道运算符的实现示例》本文简要介绍C++20管道运算符的使用与实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录标准库的管道运算符使用自己实现类似的管道运算符我们不打算介绍太多,因为它实际属于c++20最为重要的

Visual Studio 2022 编译C++20代码的图文步骤

《VisualStudio2022编译C++20代码的图文步骤》在VisualStudio中启用C++20import功能,需设置语言标准为ISOC++20,开启扫描源查找模块依赖及实验性标... 默认创建Visual Studio桌面控制台项目代码包含C++20的import方法。右键项目的属性:

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的

c++中的set容器介绍及操作大全

《c++中的set容器介绍及操作大全》:本文主要介绍c++中的set容器介绍及操作大全,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录​​一、核心特性​​️ ​​二、基本操作​​​​1. 初始化与赋值​​​​2. 增删查操作​​​​3. 遍历方

解析C++11 static_assert及与Boost库的关联从入门到精通

《解析C++11static_assert及与Boost库的关联从入门到精通》static_assert是C++中强大的编译时验证工具,它能够在编译阶段拦截不符合预期的类型或值,增强代码的健壮性,通... 目录一、背景知识:传统断言方法的局限性1.1 assert宏1.2 #error指令1.3 第三方解决