题解:洛谷 P1618 三连击(升级版)

【题目来源】

洛谷:P1618 三连击(升级版) - 洛谷 (luogu.com.cn)

【题目描述】

\(1,2,\dots, 9\)\(9\) 个数分成三组,分别组成三个三位数,且使这三个三位数的比例是 \(A:B:C\),试求出所有满足条件的三个三位数,若无解,输出 No!!!

【输入】

三个数,\(A,B,C\)

【输出】

若干行,每行 \(3\) 个数字。按照每行第一个数字升序排列。

【输入样例】

1 2 3

【输出样例】

192 384 576
219 438 657
273 546 819
327 654 981

【解题思路】

image

【算法标签】

《洛谷 P1618 三连击(升级版)》 #模拟# #字符串# #枚举#

【代码详解】

#include <bits/stdc++.h>
using namespace std;

int main() {
    int a, b, c, n1, n2, n3, flag=1, ans=0;
    int ls[15] = {0};  // 用于统计数字1-9出现次数的数组
  
    cin >> a >> b >> c;  // 输入三个比例系数
  
    // 遍历可能的num值(1到1000/c)
    for (int num=1; num<=1000/c; num++) {
        // 计算三个数的当前值
        n1 = num*a;
        n2 = num*b;
        n3 = num*c;
    
        // 分解n1的各位数字并统计
        for (int i=1; i<=3; i++) {
            ls[n1%10]++;  // 记录最低位数字
            n1 = n1/10;   // 去掉最低位
        }
    
        // 分解n2的各位数字并统计
        for (int i=1; i<=3; i++) {
            ls[n2%10]++;
            n2 = n2/10;
        }
    
        // 分解n3的各位数字并统计
        for (int i=1; i<=3; i++) {
            ls[n3%10]++;
            n3 = n3/10;
        }
    
        // 检查数字1-9是否各出现一次
        for (int i=1; i<=9; i++) {
            if (ls[i]!=1) {  // 如果有数字出现次数不为1
                flag = 0;
                break;
            }
        }
    
        // 如果满足条件,输出结果
        if(flag) {
            cout << num*a << " " << num*b << " " << num*c << endl; 
            ans++;  // 增加有效解计数
        }
        else flag = 1;  // 重置标志
    
        // 清空统计数组
        for (int i=1; i<=9; i++) ls[i] = 0;
    }
  
    // 如果没有找到解,输出提示
    if (!ans) cout << "No!!!";
  
    return 0;
}

【运行结果】

1 2 3
192 384 576
219 438 657
273 546 819
327 654 981
posted @ 2026-02-17 15:49  团爸讲算法  阅读(9)  评论(0)    收藏  举报