- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个任务,我们需要获取一个字符串 s 和一个位置 pos,并且我需要“收集”该位置的所有整数。例如,说 3 abcdef123 应该输出 abc123def(整数从位置 3 开始)。接受这些参数的主要位置未显示。
示例输入可能如下所示:
5 ab1cdefgh (the 1 moves to the 5th index)
6 1abcdefgh (the 1 moves to the 6th index)
8 1abcdefgh (the 1 moves to the end)
8 abcdefgh1 (the 1 doesn't move)
0 1abcdefgh
-1 (quit)
void gatherDigits(std::string& s, const int pos) {
int ints = 1;
int size = s.size();
for (int i = 0; i < size; i++) {
if (std::isdigit(s.at(i))) {
ints++;
}
}
s = "";
char letter;
char l;
int count = 0;
for (letter = 'a'; letter <= 'z'; letter++) {
if (count == pos) {
l = letter;
break;
}
s = s + letter;
count++;
}
for (int i = 1; i < ints; i++) {
if (i == 10) {
s = s + std::to_string(0);
}
else {
s = s + std::to_string(i);
}
}
for (int i = pos + ints; i < size + 1; i++) {
s = s + l;
l++;
}
}
但是,我遇到了一个困境。我不确定这是否被认为是硬编码(我们明确指示不要硬编码)。我们被允许使用的唯一变量是 int 和 char,这就是我以这种方式设置它的原因。此外,所有输入示例都是小写的 a-z 和 0-9 整数。我们的代码必须在 O(n^2) 时间内运行。
一个更困难的输入可能是这样的:
6 12ab3cdefghij456klm7n8op9q0
建议的解决方案涉及使用交换语句。除了缺少交换语句外,我的代码满足所有其他要求。最后,我只想问:这是否符合硬编码的条件?
最佳答案
你所做的硬编码是期望字符串中的字母以 a
开头并构建一个序列 abcd....
并且你的数字形式 1234...
。我不能说这是否会被您的主管认为是硬编码,但它肯定会使您的代码非常不灵活,并且只有在问题描述中明确说明这些属性时我才会这样做。
关于交换的部分可能是指将实际字符交换到字符串中的适当位置,而不是拆除整个字符串并创建一个新字符串,这只有在上述假设下才有可能。
正如评论中所暗示的那样,如果允许您使用标准算法,则可以大大简化和概括您的解决方案。一种可能性是例如是:
void gatherDigits(std::string& s, const int pos) {
//moves all digits to the start of the range and returns the number of digits
int cnt = std::stable_partition(s.begin(), s.end(), ::isdigit) - s.begin();
//make sure we don't write past the end of the string
assert(pos+cnt < s.size());
//rotates the string such that the digits start at the correct place
std::rotate(s.begin(), s.begin() + cnt, s.begin() + pos + cnt);
}
关于c++ - 这被认为是硬编码吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35424756/
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
class Person def name puts "Doharey" end end puts Person.class #=> this out puts Class puts
在 PHP 中,($myvariable==0)当 $myvariable 为零时,表达式的值为真;当 $myvariable 为 null 时,此表达式的值也为 true。如何排除第二种情况?我的意
正文 Oracle的一顿猛如虎操作,让开发者彻底失去了Java EE。Eclipse基金会则自立门户,另起炉灶开启Jakarta EE项目。 对于Jakarta EE,从它
我是 python 新手,建议我使用 Canopy。我正在努力跟进 with this tutorial ,但我陷入了 mahotas.imread 行。我收到一个错误,说以这个结尾: Full er
上下文是我们想要跟踪应用程序的用户行为,因为它具有不同的功能。 为此,我们创建了一个自定义 Angular Directive(指令),例如myFunctionality并将 HTML 部分包装到此指
我正在尝试在文本字段中实现 google Places api 的自动完成功能。这是我的代码: $(document).ready(function() { initialize(){ v
我在 Glassfish 3.1.1 中配置了一个新的 jdbcRealm 并打开了 FINEST 日志记录,当我尝试使用用户名和密码登录时,我得到以下信息。它提示我的 Web 应用程序映射到的领域是
问题是,即使我将线程设置为“thrd.IsBackground = false”,iis 也不认为它正在运行,即使这是一个长时间运行的进程。如果我不关闭应用程序池的空闲关闭,它将关闭,因为它认为它是空
我正在使用 OpenJDK 8(从 https://jdk.java.net/java-se-ri/8 下载并解压,添加到 PATH),并且遇到了证书错误。 经过调查,我意识到 cacerts 存在问
我基于 Firebase 制作了简单的后期制作项目。我将帖子保存到 Firebase 中,如下所示: let data = UIImageJPEGRepresentation(newPostImage
我觉得还是先说明情况比较好。 情况 我正在编写一些软件来过滤 Set 的 File。 过滤器如下:如果文件未隐藏,则将其添加到新的 Set。 问题在于 File.isHidden() 的当前行为如下:
我创建了一个 C++ DLL 函数,它使用多个数组来处理最终的图像数据。我正在尝试通过引用传递这些数组,进行计算,然后通过预分配数组中的引用将输出传回。在该函数中,我使用了 Intel Perform
我在 python 中有一个小应用程序,除了这个小问题之外,它工作得很好:它应该连续运行一个循环,直到用户通过按钮告诉它停止,但是当我点击开始按钮时,Windows 告诉我它不是回应。现在,如果我编写
代码运行正常,但我怎么会得到这个错误日志 错误日志: 08-28 08:44:24.281: E/MediaPlayer(32454): mOnVideoSizeChangedListener is
我有一个使用 Karma+Jasmine 和 JSHint 的 Grunt 设置。每当我在我的规范文件上运行 JSHint 时,我都会收到一系列“未定义”错误,其中大部分是针对 Jasmine 的内置
将以下代码保存到文件中,Ubuntu 14.04 正确地意识到它是 bash: #!/usr/bin/env bash awk '{print $1 $2}' my_file 然而,向 awk 添加关
以下代码返回 false import inspect print(inspect.isbuiltin(map)) 但是 map 功能在"built-in" functions下列出. 为什么会这样?
这是一段常见的示例代码: while (1) { print "foo\n"; } 永远打印“foo”。 perl foo.pl foo foo foo ... 和 while (0) { p
我对 Haskell 比较陌生,来自 F#(一种 Microsoft 语言)。 我已经从脚手架创建了一个 Yesod 项目,稍微玩了一下,调整了一些东西,但随后它停止工作,并显示此错误消息(在所有模块
我是一名优秀的程序员,十分优秀!