【C++✨】多种 C++ 解法固定宽度右对齐输出(每个数占 8 列)

题目概述

  • 输入 :一行三个整数 a b c(空格分隔)。
  • 输出 :一行,依次输出三数;每个数占 8 个字符宽度且右对齐 ,三个数之间一个空格
  • 数字超出 8 位时不截断,照常完整输出。

关键点

  • 右对齐 + 固定最小宽度 8;不足在左侧补空格。
  • 三个数之间仅放一个空格;行末不要多余空格。
  • 下例中用 long long 覆盖范围更稳(当然用 int 也可)。

方法一:<iomanip>setw(推荐)

cpp 复制代码
#include <iostream>
#include <iomanip>
using namespace std;

int main() {
    long long a[3];
    cin >> a[0] >> a[1] >> a[2];

    cout << setw(8) << a[0] << " "
         << setw(8) << a[1] << " "
         << setw(8) << a[2] << '\n';
    return 0;
}

要点setw(8) 表示至少占 8 列,默认右对齐;宽度不足左侧补空格,超出不截断。


方法二:C 风格 printf

cpp 复制代码
#include <cstdio>

int main() {
    long long a[3];
    if (scanf("%lld %lld %lld", &a[0], &a[1], &a[2]) == 3) {
        // %8lld => 右对齐、宽度为 8
        printf("%8lld %8lld %8lld\n", a[0], a[1], a[2]);
    }
    return 0;
}

要点%8lld 右对齐且宽度 8。


方法三:手工补空格(不依赖格式库)

cpp 复制代码
#include <iostream>
#include <string>
using namespace std;

string rightPad8(long long x) {
    string s = to_string(x);
    int pad = 8 - (int)s.size();
    if (pad < 0) pad = 0;                // 超过 8 位不补
    return string(pad, ' ') + s;         // 左侧补空格
}

int main() {
    long long a[3];
    cin >> a[0] >> a[1] >> a[2];

    cout << rightPad8(a[0]) << " "
         << rightPad8(a[1]) << " "
         << rightPad8(a[2]) << '\n';
    return 0;
}

要点:把数字转字符串,计算需要补的空格数量并在左侧补齐。


方法四:ostream::width()(流对象原生方法)

cpp 复制代码
#include <iostream>
using namespace std;

int main() {
    long long a[3];
    cin >> a[0] >> a[1] >> a[2];

    cout.width(8); cout << a[0] << " ";
    cout.width(8); cout << a[1] << " ";
    cout.width(8); cout << a[2] << '\n';
    return 0;
}

要点width(8) 仅对下一次插入有效,需每次设置。


测试样例

输入

复制代码
123456789 0 -1

输出

复制代码
123456789        0       -1

编译与运行(Dev-C++ / g++)

  • 直接把任一方法保存为 main.cpp,在 Dev-C++ 中新建控制台项目编译运行即可。
  • 命令行(可选):
bash 复制代码
g++ -std=c++11 -O2 -pipe -o main main.cpp
./main
相关推荐
晨曦(zxr_0102)4 分钟前
CSP-X 2024 复赛编程题全解(B4104+B4105+B4106+B4107)
数据结构·c++·算法
ai安歌5 分钟前
【Rust编程:从新手到大师】 Rust 控制流深度详解
开发语言·算法·rust
Shinom1ya_7 分钟前
算法 day 36
算法
·白小白8 分钟前
力扣(LeetCode) ——15.三数之和(C++)
c++·算法·leetcode
海琴烟Sunshine10 分钟前
leetcode 268. 丢失的数字 python
python·算法·leetcode
czhc114007566311 分钟前
JAVA1027抽象类;抽象类继承
android·java·开发语言
CL.LIANG13 分钟前
视觉SLAM前置知识:相机模型
数码相机·算法
练习时长一年19 分钟前
jdk动态代理的实现原理
java·开发语言
无限进步_29 分钟前
深入理解C语言scanf函数:从基础到高级用法完全指南
c语言·开发语言·c++·后端·算法·visual studio
Wild_Pointer.36 分钟前
Qt Creator:避免QRunnable和QObject多重继承
开发语言·qt