删数问题
2015-11-17 17:40
253 查看
题目:
键盘输入一个高精度的正整数n(<=240位),
去掉任意s个数字后剩下的数字按原左右次序将组成一个新的正整数。
编程对给定的n和s,寻找一种方案,使得剩下的数最小。
Simple Input
178543
4
Simple Output
13
思路:
每一步总是选择一个使剩下的数最小的数字删除,即按高位到低位的顺序搜索,若各位数字递增,则删除最后一个数字;否则删除第一个递减区间的首字符,这样删一位便形成了一个新的数字串。然后回到串首,按上述规则再删除下一个数字
代码:
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<string>
#include<cmath>
#include<iostream>
using namespace std;
#pragma warning(disable:4996)
int main()
{
string s;
int k;
cin >> s >> k;
if (k >= (s.size()))
s.erase();
else
{
while (k>0)
{
int i;
for (i = 0; (i < s.size() && s[i] <= s[i + 1]); i++);
s.erase(i, 1);
k--;
}
}
while ( s.size() >0 && s[0] == '0') //删除前导0
{
s.erase(0, 1);
}
cout << s << endl;
//system("pause");
return 0;
}
键盘输入一个高精度的正整数n(<=240位),
去掉任意s个数字后剩下的数字按原左右次序将组成一个新的正整数。
编程对给定的n和s,寻找一种方案,使得剩下的数最小。
Simple Input
178543
4
Simple Output
13
思路:
每一步总是选择一个使剩下的数最小的数字删除,即按高位到低位的顺序搜索,若各位数字递增,则删除最后一个数字;否则删除第一个递减区间的首字符,这样删一位便形成了一个新的数字串。然后回到串首,按上述规则再删除下一个数字
代码:
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<string>
#include<cmath>
#include<iostream>
using namespace std;
#pragma warning(disable:4996)
int main()
{
string s;
int k;
cin >> s >> k;
if (k >= (s.size()))
s.erase();
else
{
while (k>0)
{
int i;
for (i = 0; (i < s.size() && s[i] <= s[i + 1]); i++);
s.erase(i, 1);
k--;
}
}
while ( s.size() >0 && s[0] == '0') //删除前导0
{
s.erase(0, 1);
}
cout << s << endl;
//system("pause");
return 0;
}
相关文章推荐
- Linux下安装nginx和php
- Solr解析器通用的查询参数
- 杭电-5500Reorder the Books
- 碎片Fragment
- 应用dts在am335x上移植LCD(三)
- 图片在沙盒中的存在形式
- iOS_打包上传appStore
- 可折叠tableView - 仿照通讯录
- Linux下安装nginx和php
- 委托 Action与Func
- POJ 2049 Finding Nemo
- 使用dom4j 把xml格式解析为对象或者对象集合
- 2015 联赛 (2)
- 应用dts在am335x上移植LCD(二)
- AVAudioPlayer的简单使用
- iOS_基于ScrollView的一个简单相册
- Eclipse上GIT插件EGIT--_Rebase和Merge的区别
- 将Python脚本打包成可执行文件
- 解析#define NULL ((void *)0)——野指针,空指针和 void*
- Java使用RSA加密解密签名及校验