1106 删数问题

1106 删数问题

难度:普及/提高-

题目类型:贪心

提交次数:3

涉及知识:字符串、贪心

题目描述

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

输出应包括所去掉的数字的位置和组成的新的正整数。(N不超过250位) 输入数据均不需判错。

代码:

#include<iostream>
#include<cstring>
using namespace std;
int main(){
    string s;
    cin>>s;
    int k;
    cin>>k;
    int n = 0;
    int i = 0;
    //cout<<bool(i<=s.length()-2)<<endl;
    while(n<k&&i<s.length()-1){
        i++;
        if(s[i-1]>s[i]){
            s.erase(i-1,1);
            n++;
            i=0;
        }
    }
    //cout<<k-n<<endl;
    for(i = 0; i < k-n; i++) 
        s.erase(s.length()-1, 1);
    for(i = 0; i < s.length(); i++){
        if(s[i]!='0') {
            cout<<s.substr(i, s.length()-i);
            return 0;
        }
    }
    if(i==s.length())cout<<'0';
    return 0;
}

备注:

感觉被诅咒一样,这道题写的特别费劲。基本思路就是贪心,找到降序就删掉第一个,然后再从头找。最开始是i、n应该是1还是0,在什么位置加1,加1还是减1还是不加不减这种小细节搞了半天,感觉智商被掏空。字符串函数用的还是不熟练,多写写就好了。另外要注意的关键就是先导0问题。ps:字符0和数字0不一样,所以不能用if(s[i])判断。另外有一个诡异的问题,就是注释的第一行,由于老师出去约饭去了,正在等待老师解答中。


得到老师解答,很神奇,s.length()的返回值的是无符号数,负数和无符号数比就出问题啦。

posted @ 2016-08-17 21:05  timeaftertime  阅读(328)  评论(0编辑  收藏  举报