【Bugs】VS单步调试的无法进入断点、行号错乱等问题解决方法

###Date: 2018.4.12

====================================================

转载自:https://blog.csdn.net/lsldd/article/details/46049481

   之前遇到过这种问题,解决方案见我的博客:https://blog.csdn.net/soaringlee_fighting/article/details/79771053

这里有一个新的原因和解决方案,没有尝试过,先转载在这里,仅供参考。

Visual Studio有时候会出现单步调试时候,断点处变成不可命中,始终提示“当前不会命中断点。源代码与原始版本不同。” 
或者就算能进入断点,单步调试时实际执行的代码与源码行号不匹配的问题。

通常原因是因为代码中有非ASCII字符等原因。

尤其是使用了拷贝的网页上的代码,或者使用了老外写的代码,容易出现这类问题。

解决方法:
1、在VS中打开该文件,打开另存为(Save as)对话框。
2、点击对话框中“保存(Save)”按钮右边的向下三角形按钮。
3、编码方式(Encoding)选择 UTF-8

4、行尾(Line Endings)选择Windows(CR LF)

如下图所示。





其他参考资料:
1、行尾标准化:
http://www.cnblogs.com/liubiqu/archive/2009/01/16/1376891.html


2、编码方式与C4819警告:
http://bbs.csdn.net/topics/390457909
https://social.msdn.microsoft.com/Forums/vstudio/en-US/94153c9d-64ad-4f41-848c-c96b359e4542/unicode-error?forum=vcgeneral
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
青蛙回家吃虫子问题是一个经典的贪心算法问题问题描述如下: 青蛙在一条数轴上,它要从起点跳到终点,途中有一些虫子,青蛙可以选择吃或不吃。每个虫子有一个位置和一个价值,青蛙在这个位置吃掉虫子可以获得这个虫子的价值。青蛙每次跳的距离不能超过它当前位置到终点的距离,即青蛙不能跳过终点。现在给定虫子的位置和价值,青蛙在起点,请问青蛙最多能获得多少价值? 这个问题可以用贪心算法来解决。贪心算法的思想是每次选择最优的局部解,最终得到全局最优解。 具体的贪心策略是:首先将所有虫子按照位置从小到大排序,然后依次考虑每个虫子。如果青蛙当前位置能够到达这个虫子,那么就吃掉这个虫子,否则就跳过这个虫子。因为青蛙每次跳的距离不能超过它当前位置到终点的距离,所以这个贪心策略是正确的。 下面是 Python 代码实现: ```python def max_value(pos, val, n, end): # pos: 虫子的位置 # val: 虫子的价值 # n: 虫子的数量 # end: 终点的位置 bugs = list(zip(pos, val)) bugs.sort() # 按照位置从小到大排序 cur_pos, ans = 0, 0 for i in range(n): if bugs[i][0] > cur_pos + end: # 跳过这个虫子 continue if bugs[i][0] > cur_pos: # 能够到达这个虫子 ans += bugs[i][1] cur_pos = bugs[i][0] if cur_pos >= end: # 到达终点 break return ans ``` 该算法的时间复杂度为 $O(n\log n)$,其中 $n$ 是虫子的数量。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值