AcWing 4609:火柴棍数字 ← 贪心算法

【题目来源】
https://www.acwing.com/problem/content/4612/

【题目描述】
给定 n 个火柴棍,你可以用它们摆出数字 0∼9。
摆出每个数字所需要的具体火柴棍数量如下图所示:

请你用这些火柴棍摆成若干个数字,并把这些数字排成一排组成一个整数,要求组成的整数尽可能大。
输出可以摆成的最大可能整数。

【输入格式】
第一行包含整数 T,表示共有 T 组测试数据。
每组数据占一行,包含一个整数 n。表示火柴根数。

【输出格式】
输出可以摆成的最大可能整数。

【数据范围】
前 3 个测试点满足 1≤t≤10。
所有测试点满足 1≤t≤100,2≤n≤10^5,同一测试点内所有 n 相加之和不超过 10^5。

【输入样例】
10
2
3
4
5
6
7
8
9
10
11

【输出样例】
1
7
11
71
111
711
1111
7111
11111
71111

【算法分析】
○ 给定的火柴棍数字中,凑出 1 需要 2 根火柴,凑出 7 需要 3 根火柴 ......
○ 位数越多的数,代表的数越大。
○ 而给定一个数,能凑出的最大位数为:
若 n 为偶数,则最多能凑出 n/2 位,每位为 1;
若 n 为奇数,依然能最多能凑出 n/2 位,其中最高位为 7,其他 n/2-1 位均为 1。

【算法代码】

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

int main() {
    int T;
    cin>>T;
    while(T--) {
        int n;
        cin>>n;
        if(n%2==0) cout<<1;
        else cout<<7;

        for(int i=1; i<n/2; i++) cout<<1;
        cout<<endl;
    }
}


/*
in:
10
2
3
4
5
6
7
8
9
10
11

out:
1
7
11
71
111
711
1111
7111
11111
71111
*/

【参考文献】
https://www.acwing.com/video/4299/
https://www.acwing.com/solution/content/136165/

相关推荐
dbln13 小时前
贪心算法(六)
算法·贪心算法
仟濹15 小时前
【贪心算法】洛谷P1090 合并果子 / [USACO06NOV] Fence Repair G
算法·贪心算法
Long_poem2 天前
【第六天】零基础入门刷题Python-算法篇-数据结构与算法的介绍-一种常见的贪心算法(持续更新)
python·算法·贪心算法
圆圆滚滚小企鹅。3 天前
刷题笔记 贪心算法-1 贪心算法理论基础
笔记·算法·leetcode·贪心算法
Milk夜雨4 天前
头歌实训作业 算法设计与分析-贪心算法(第3关:活动安排问题)
算法·贪心算法
仟濹4 天前
【贪心算法】洛谷P1106 - 删数问题
c语言·c++·算法·贪心算法
银河梦想家4 天前
【Day23 LeetCode】贪心算法题
leetcode·贪心算法
懒羊羊大王&4 天前
179最大数(贪心算法)分析+源码+证明
算法·贪心算法
DogDaoDao5 天前
leetcode 面试经典 150 题:插入区间
c++·算法·leetcode·面试·贪心算法·vector·插入区间
m0_dawn6 天前
《贪心算法:原理剖析与典型例题精解》
python·算法·职场和发展·贪心算法·蓝桥杯