HDU 5676 ztr loves lucky numbers (模拟)
ztr loves lucky numbers
题目链接:
http://acm.hust.edu.cn/vjudge/contest/121332#problem/I
Description
ztr loves lucky numbers. Everybody knows that positive integers are lucky if their decimal representation doesn't contain digits other than 4 and 7. For example, numbers 47, 744, 4 are lucky and 5, 17, 467 are not.
Lucky number is super lucky if it's decimal representation contains equal amount of digits 4 and 7. For example, numbers 47, 7744, 474477 are super lucky and 4, 744, 467 are not.
One day ztr came across a positive integer n. Help him to find the least super lucky number which is not less than n.
Input
There are T cases
For each cases:
The only line contains a positive integer . This number doesn't have leading zeroes.
Output
For each cases
Output the answer
Sample Input
2
4500
47
Sample Output
4747
47
题意:
定义super number:
有且仅有4和7两个数字,且两个数字出现的次数相同.
给出n,求最小的不小于n的super number
题解:
xjb打了一通大模拟,结果越打越觉得坑;
还好分清细节后过掉了;
模拟思路:考虑当前数位能是否能放4或7(用strcmp比较后续数);
当两数大小确定后,后面的序列应按最小顺序编排;
另解:
- 直接打表然后二分.
- 用next_permutation获取可能的组合再比较.
代码:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
#include <algorithm>
#include <queue>
#include <map>
#include <set>
#include <vector>
#define LL long long
#define eps 1e-8
#define maxn 3100
#define inf 0x3f3f3f3f
#define IN freopen("in.txt","r",stdin);
using namespace std;
char num[25];
int cnt;
int main(int argc, char const *argv[])
{
    //IN;
    //freopen("out.txt","w",stdout);
//    printf("%d\n", 1000000);
//    for(int i=1; i<=1000000; i++)
//        printf("%d\n", i);
    int t; cin >> t; getchar();
    //int t = 0;
    while(t--)
    {
        LL n=0,cmps=0;
        char c;
        cnt = 0;
        memset(num,0,sizeof(num));
        gets(num);
        for(int i=0; i<strlen(num); i++) {
            if(num[i]<'0' || num[i]>'9') break;
            cnt++;
            n = n*10 + num[i] - '0';
        }
        num[cnt] = 0;
        if(cnt&1) {
            for(int i=1; i<=(cnt+1)/2; i++) printf("4");
            for(int i=1; i<=(cnt+1)/2; i++) printf("7");
            printf("\n");
            continue;
        }
        for(int i=1; i<=cnt/2; i++) cmps = cmps*10 + 7;
        for(int i=1; i<=cnt/2; i++) cmps = cmps*10 + 4;
        if(cmps < n) {
            for(int i=1; i<=(cnt+2)/2; i++) printf("4");
            for(int i=1; i<=(cnt+2)/2; i++) printf("7");
            printf("\n");
            continue;
        }
        char ans[25] = {0};
        int si=cnt/2,qi=cnt/2;
        for(int i=0; i<cnt; i++) {
            if(num[i]<'4') {
                if(si) ans[i] = '4', si--;
                else ans[i] = '7', qi--;
                for(int j=0; j<=i; j++) printf("%c", ans[j]);
                while(si--) printf("4");
                while(qi--) printf("7");
                printf("\n");
                break;
            }
            if(num[i] == '4') {
                char tmp[25] = {0};
                for(int j=0; j<qi; j++) tmp[j] = '7';
                for(int j=qi; j<qi+si-1; j++) tmp[j] = '4';
                if(!si || strcmp(tmp,num+i+1) < 0) {
                    ans[i] = '7'; qi--;
                    for(int j=0; j<=i; j++) printf("%c", ans[j]);
                    while(si--) printf("4");
                    while(qi--) printf("7");
                    printf("\n");
                    break;
                }
                if(strcmp(tmp,num+i+1) == 0) {
                    ans[i] = '4'; si--;
                    for(int j=0; j<=i; j++) printf("%c", ans[j]);
                    printf("%s",tmp);
                    printf("\n");
                    break;
                }
                ans[i] = '4'; si--;
                continue;
            }
            if(num[i] == '7') {
                char tmp[25] = {0};
                for(int j=0; j<qi-1; j++) tmp[j] = '7';
                for(int j=qi-1; j<qi+si-1; j++) tmp[j] = '4';
                if(!qi || strcmp(tmp,num+i+1) < 0) {
                    for(int i=1; i<=(cnt+2)/2; i++) printf("4");
                    for(int i=1; i<=(cnt+2)/2; i++) printf("7");
                    printf("\n");
                    break;
                }
                if(strcmp(tmp,num+i+1) == 0) {
                    ans[i] = '7'; qi--;
                    for(int j=0; j<=i; j++) printf("%c", ans[j]);
                    printf("%s",tmp);
                    printf("\n");
                    break;
                }
                ans[i] = '7'; qi--;
                continue;
            }
            ans[i] = '7'; qi--;
            for(int j=0; j<=i; j++)
                printf("%c", ans[j]);
            while(si--) printf("4");
            while(qi--) printf("7");
            printf("\n");
            break;
        }
        //printf("\n");
    }
    return 0;
}
HDU 5676 ztr loves lucky numbers (模拟)的更多相关文章
- hdu 5676 ztr loves lucky numbers(dfs+离线)
		Problem Description ztr loves lucky numbers. Everybody knows that positive integers are lucky if the ... 
- hdu 5676 ztr loves lucky numbers 打表+二分
		ztr loves lucky numbers Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/ ... 
- hdu 5676 ztr loves lucky numbers
		题目链接:hdu 5676 一开始看题还以为和数位dp相关的,后来才发现是搜索题,我手算了下,所有的super lucky number(也就是只含数字4, 7且4, 7的数量相等的数)加起来也不过几 ... 
- HDU 5676 ztr loves lucky numbers【DFS】
		题目链接; http://acm.hdu.edu.cn/showproblem.php?pid=5676 题意: 由4和7组成的且4和7出现次数相同的数称为幸运数字,给定n,求不大于n的最大幸运数字. ... 
- hdu-5676 ztr loves lucky numbers(乱搞题)
		题目链接: ztr loves lucky numbers Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K ( ... 
- ztr loves lucky numbers 傻逼的我来了个大模拟
		http://acm.hdu.edu.cn/showproblem.php?pid=5676 这题的正解因该是dfs的,但是有18个位,然后我一算,全排列的话,有18!个啊,那不是很大?但是有很多是相 ... 
- hdu5676 ztr loves lucky numbers(dfs)
		链接 ztrloveslucky numbers 题意 定义幸运数为:只存在4和7且4和7数量相等的数,给出n,求比>=n的最小幸运数 做法 暴力搜出所有长度从2-18的幸运数,因为最多9个4, ... 
- HDU 5677 ztr loves substring(Manacher+dp+二进制分解)
		题目链接:HDU 5677 ztr loves substring 题意:有n个字符串,任选k个回文子串,问其长度之和能否等于L. 题解:用manacher算法求出所有回文子串的长度,并记录各长度回文 ... 
- HDU 5675 ztr loves math (数学推导)
		ztr loves math 题目链接: http://acm.hust.edu.cn/vjudge/contest/123316#problem/A Description ztr loves re ... 
随机推荐
- Android 下log的使用总结
			Android 下log的使用总结 一:在源码开发模式下 1:包含头文件: #include <cutils/log.h> 2:定义宏LOG_TAG #define LOG_TAG &qu ... 
- IS_ERR、PTR_ERR、ERR_PTR
			最近在使用filp_open打开文件时遇到到一个问题,当打开一个并不存在的文件时,filp_open返回值值为0xfffffffe,而并不是0(NULL),这是因为内核对返回指针的函数做了特殊处理.内 ... 
- Effective C++学习笔记 条款07:为多态基类声明virtual析构函数
			一.C++明确指出:当derived class对象经由一个base class指针被删除,而该base class带着一个non-virtual析构函数,其结果未定义——实际执行时通常发生的是对象的 ... 
- [LeetCode#247] Strobogrammatic Number II
			Problem: A strobogrammatic number is a number that looks the same when rotated 180 degrees (looked a ... 
- iOS开发:告诉git不要跟踪UserInterfaceState.xcuserstate
			在xcode中使用git管理项目的技巧: 在多人协作开发的时候,每个开发者都会在项目中的某个目录生成一个 UserInterfaceState.xcuserstate 文件,这个文件大概每5s会刷新一 ... 
- UWP:本地应用数据
			获取应用的设置和文件容器 使用 ApplicationData.LocalSettings 属性可以获取 ApplicationDataContainer 对象中的设置. 注意:每个设置的名称最长可为 ... 
- 【转】JAVA之网络编程
			转自:火之光 网络编程 网络编程对于很多的初学者来说,都是很向往的一种编程技能,但是很多的初学者却因为很长一段时间无法进入网络编程的大门而放弃了对于该部分技术的学习. 在 学习网络编程以前,很多初学者 ... 
- linux lnmp编译安装
			关闭SELINUX vi /etc/selinux/config #SELINUX=enforcing #注释掉 #SELINUXTYPE=targeted #注释掉 SELINUX=disabled ... 
- Liunx系统学习一,liunx系统的目录结构及含义
			LIUNX系统目录结构: “/” ===>这是linux文件系统的入口,也是整个linux文件系统的根目录,linux不同于windows,没有所谓的C,D,E盘,整个liunx只有一个根分区 ... 
- 【c++内存分布系列】单独一个类
			首先要明确类型本身是没有具体地址的,它是为了给编译器生成相应对象提供依据.只有编译器生成的对象才有明确的地址. 一.空类 形如下面的类A,类里没有任何成员变量,类的sizeof值为1. #includ ... 
