【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
相关推荐
木心月转码ing42 分钟前
Hot100-Day10-T438T438找到字符串中所有字母异位词
算法
HelloReader1 小时前
Wi-Fi CSI 感知技术用无线信号“看见“室内的人
算法
颜酱4 小时前
二叉树分解问题思路解题模式
javascript·后端·算法
qianpeng8975 小时前
水声匹配场定位原理及实验
算法
董董灿是个攻城狮17 小时前
AI视觉连载8:传统 CV 之边缘检测
算法
blasit1 天前
笔记:Qt C++建立子线程做一个socket TCP常连接通信
c++·qt·tcp/ip
AI软著研究员1 天前
程序员必看:软著不是“面子工程”,是代码的“法律保险”
算法
FunnySaltyFish1 天前
什么?Compose 把 GapBuffer 换成了 LinkBuffer?
算法·kotlin·android jetpack
颜酱1 天前
理解二叉树最近公共祖先(LCA):从基础到变种解析
javascript·后端·算法
地平线开发者2 天前
SparseDrive 模型导出与性能优化实战
算法·自动驾驶