为什么在这个代码中有分段错误

Why is there a segmentation fault in this code ?

本文关键字:分段 错误 代码 为什么      更新时间:2023-10-16

我想比较两个数字字符串,计算相同数字出现的次数

#include <cstdlib>
#include <iostream>
using namespace std;
void function(string number1, string number2)
{
   int taille = number1.size();
   int tab[]={0,0,0,0,0,0,0,0,0,0};
   int chiffre=0;
   for (int i=0; i<taille;i++) {
       for (int j=0;j<taille;j++){
           if (number1[i]==number2[j])
           {
              cout <<  "chiffre " <<number1[i]<< endl;
              chiffre = number1[i];
              tab[chiffre]++; 
           }
        }
   }
   for (int i=0; i<10;i++) {
       if (tab[i]!=0)
       cout << "index " << i<< " value "<<  tab[i]<< endl;
   }
}
int main(int argc, char *argv[])
{
     string number1 = "5143436111";
     string number2 = "4501234567";
    function(number1,number2);
    cout << "Press the enter key to continue ...";
    cin.get();
    return EXIT_SUCCESS;
}

带tab[chiffre]++;程序似乎要崩溃了。请告诉我为什么

您需要:

chiffre = number1[i]-'0';

还有这个:

   int taille = number1.size();

但是如果number1和number2的大小不同呢?然后你的内部循环(例如,如果number2小于number1, for (int j=0;j<taille;j++)可以索引number2,或者如果number2大于number1,它将不会循环足够。

问题在这一行:

chiffre = number1[i];

当您将数字分配给chiffre时,它不会将其分配为数字(从0到9),而是作为ASCII码(从'0'到'9')。

您可以使用以下命令将其转换为数字:

chiffre = number1[i] - '0';

当您使用tab["5"]时,您使用的是5的ascii值,即53,超出了10的范围你需要转换ascii值或者使用tab [chiffre-48]48在ascii中是'0'

在这一行:

chiffre = number1[i];

您正在将字符(例如'5')转换为整数。应该是:

chiffre = number1[i] - '0';

我不知道你到底想要得到什么,但我猜你只是想比较number1的第一个数字和number2的第一个数字,你假设两个长度相同的数字?在这种情况下,你的循环应该变成这样:

if (number1.size() == number2.size()){
    for (int i=0; i<taille;i++) {
           if (number1[i]==number2[i])
           {
              cout <<  "chiffre " <<number1[i]<< endl;
              chiffre = number1[i] - '0';
              tab[chiffre]++; 
           }
       }
   }

number1[i]包含一些字符,例如'5'。其ASCII码为53。这个数组没有53个元素。

修改语句

          chiffre = number1[i];

          chiffre = number1[i] - '0';

你的算法也不能正常工作。例如,如果number1等于"55", number2等于45,那么你的算法打印出数字5包含在number2中两次。