Catcheryp 2016-03-07 15:57 采纳率: 100%
浏览 1858
已采纳

C++程序里面一个很奇怪的bug!跪求解释!!!

这是我试图求解leetcode 第六题,这不重要,主要看一下程序里面那个if语句的执行
问题,不用看我针对这道题的逻辑对不对,这不是重点,重点是那个if语句!!!
在代码那个(***)的地方我给了注释!!!

 #include <iostream>
#include <string>
#include <cstring>
using namespace std;
int main()
{
    string s;
    int numRows;
    cin >> s >> numRows;
    char *ss = new char[s.size()];
    int k = 2 * numRows - 2;//每个单元元素的个数
    int m = s.size() / k;//一共有多少个单元
    int flag = s.size()  % k;
    if(flag != 0)
        m++;
    int n = 2 * m;
    //先对第一行单独处理
    for(int i = 0, j = 0; j < m; ++j, i = i + k)
    {
        ss[j] = s[i];
    }
    //对第二行至倒数第二行的处理
    //i =(所在行 - 1)
    //j =(所在列 - 1)
    int count = 0;
    int i = 1, j = 0;
    int x;
    cout << endl;
    while(i < numRows - 1)
    {
        while(count < n)
        {
            //偶数列时要加上行数,奇数列时要减去行数
            if(j % 2 == 1)
                x = 1;
            else
                x = -1;
            int num = (j / 2 + j % 2);//0 1 2 3 4 5 6 -> 0 1 1 2 2 3 3 

            cout << "k:" << k << '\n' << "num:" << num << '\n';
            cout << "i:" << i << '\n' << "x:" << x << '\n';
            cout << "s.size():" << s.size() << endl;

            //这里输入PAYPALISHIRING 3 之后 k=4,num=0,i=1,x=-1,s.size()=14明显if语句执行不了,
            //但是居然执行了,我好郁闷啊!!!求解!!! 

         (***)   if((k*num+i*x) >= s.size())
            {
                cout << "DDDDDDDDD"  << endl;
                break;
            }
            //m代表第一行元素的个数
            cout << "CCCCCCCCCC" << endl;
            ss[m+n*(i-1)+j] = s[k*num+i*x];
            cout << s[k*num+i*x];
            j++;
            count++;
        }
        i++;
    }
    //对最后一行进行处理
    i--;
    j--;
    for(int jj = m+n*(i-1)+j, ii = numRows-1; ii < s.size() && jj < s.size(); ++jj, ii = ii + k)
    {
        ss[jj] = s[ii];
    }

    cout << ss << endl;
    return 0;
}
  • 写回答

4条回答 默认 最新

  • u52983610 2016-03-07 16:34
    关注

    s.size()返回的是unsigned int,如果不强制转换成int类型的话,就会用一个-1的int和14的unsignedint比较,-1转换成unsigned int会是一个很大的数值

     if((k*num+i*x) >= ((int)s.size())) 
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥30 求一段fortran代码用IVF编译运行的结果
  • ¥15 深度学习根据CNN网络模型,搭建BP模型并训练MNIST数据集
  • ¥15 lammps拉伸应力应变曲线分析
  • ¥15 C++ 头文件/宏冲突问题解决
  • ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
  • ¥50 安卓adb backup备份子用户应用数据失败
  • ¥20 有人能用聚类分析帮我分析一下文本内容嘛
  • ¥15 请问Lammps做复合材料拉伸模拟,应力应变曲线问题
  • ¥30 python代码,帮调试,帮帮忙吧
  • ¥15 #MATLAB仿真#车辆换道路径规划