zoukankan      html  css  js  c++  java
  • 4906 删数问题

    4906 删数问题

     

    时间限制: 1 s
    空间限制: 2000 KB
    题目等级 : 黄金 Gold
     
     
     
    题目描述 Description

      键盘输入一个高精度的正整数N,去掉其中任意S个数字后剩下的数字按原左右次序将组成一个新的正整数。编程对给定的N 和S,寻找一种方案使得剩下的数字组成的新数最小。 

      输入数据均不需要判错。 

      输出组成的新的正整数。(N不超过240位)

    输入描述 Input Description

    第一行,输入一正整数N(N<=10240),表示要删的数;

    第二行,输入一正整数S,表示删去的个数,当然S小于N的位数。

    输出描述 Output Description

    仅一行,输出删数后形成的最小数。

    样例输入 Sample Input

    【1】

    5768

    1

    【2】

    8796542

    4

    样例输出 Sample Output

    【1】

    568

    【2】

    542

    数据范围及提示 Data Size & Hint

    1<=N<=10240

    1<=S<=239

    注意开头的0应略去!![要小心

     1 #include<string>
     2 #include<iostream>
     3 using namespace std;
     4 int main() 
     5 {
     6     int n;
     7     string s;
     8     cin >> s >> n;
     9     for (int i;i = 0, n--; s.erase(i, 1)) //quanweizhen
    10      {
    11          while (i < s.size() && s[i] <= s[i + 1])
    12          {
    13            ++i;
    14          }    
    15      }
    16     while (s.size() > 1 && s[0] == '0')
    17     {
    18        s.erase(0, 1);
    19     }
    20     cout << s << endl;
    21     return 0;
    22 }
  • 相关阅读:
    C++覆盖、重载、多态区别
    C++的模板与类属类
    虚函数表和虚基类表
    常用的设计模式
    计算机内存中的对齐和C++ 类的存储空间大小
    C++的多态
    前端框架你究竟选什么
    [zt]程序员的本质
    javascript
    Web开发人员应有的15本免费电子书
  • 原文地址:https://www.cnblogs.com/lyqlyq/p/6758493.html
Copyright © 2011-2022 走看看