信息学奥赛一本通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

相关文章

Linux下如何使用C++获取硬件信息

《Linux下如何使用C++获取硬件信息》这篇文章主要为大家详细介绍了如何使用C++实现获取CPU,主板,磁盘,BIOS信息等硬件信息,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录方法获取CPU信息:读取"/proc/cpuinfo"文件获取磁盘信息:读取"/proc/diskstats"文

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient

C++中初始化二维数组的几种常见方法

《C++中初始化二维数组的几种常见方法》本文详细介绍了在C++中初始化二维数组的不同方式,包括静态初始化、循环、全部为零、部分初始化、std::array和std::vector,以及std::vec... 目录1. 静态初始化2. 使用循环初始化3. 全部初始化为零4. 部分初始化5. 使用 std::a

SpringValidation数据校验之约束注解与分组校验方式

《SpringValidation数据校验之约束注解与分组校验方式》本文将深入探讨SpringValidation的核心功能,帮助开发者掌握约束注解的使用技巧和分组校验的高级应用,从而构建更加健壮和可... 目录引言一、Spring Validation基础架构1.1 jsR-380标准与Spring整合1

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

SpringBatch数据写入实现

《SpringBatch数据写入实现》SpringBatch通过ItemWriter接口及其丰富的实现,提供了强大的数据写入能力,本文主要介绍了SpringBatch数据写入实现,具有一定的参考价值,... 目录python引言一、ItemWriter核心概念二、数据库写入实现三、文件写入实现四、多目标写入

C++ vector的常见用法超详细讲解

《C++vector的常见用法超详细讲解》:本文主要介绍C++vector的常见用法,包括C++中vector容器的定义、初始化方法、访问元素、常用函数及其时间复杂度,通过代码介绍的非常详细,... 目录1、vector的定义2、vector常用初始化方法1、使编程用花括号直接赋值2、使用圆括号赋值3、ve

使用Python将JSON,XML和YAML数据写入Excel文件

《使用Python将JSON,XML和YAML数据写入Excel文件》JSON、XML和YAML作为主流结构化数据格式,因其层次化表达能力和跨平台兼容性,已成为系统间数据交换的通用载体,本文将介绍如何... 目录如何使用python写入数据到Excel工作表用Python导入jsON数据到Excel工作表用

Mysql如何将数据按照年月分组的统计

《Mysql如何将数据按照年月分组的统计》:本文主要介绍Mysql如何将数据按照年月分组的统计方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql将数据按照年月分组的统计要的效果方案总结Mysql将数据按照年月分组的统计要的效果方案① 使用 DA