为什么这个程序(而不是段)使整个程序崩溃

Why is this program(rather the segment) crashing the whole program

本文关键字:程序 崩溃 为什么      更新时间:2023-10-16

我一直在挠头,想知道为什么我的程序崩溃了。我的目标是扫描一根弦,并获取每个子弦的频率!

程序崩溃的实数部分(M是字符串,int类型的映射)我的输入:字符串是"abab",当 i=0 和 j 在 M[e]++ 语句处等于 3 时,程序崩溃!

    for(i=0;str[i];i++)
        {
            char temp[5001];
            k=0;
            cout<<str[i]<<endl;
            for(j=i;str[j];j++)
                {
                    temp[k]=(char)str[j];
                    k++;
                    temp[k]='';
                    string e(temp);
                    M[e]++;
                    cout<<j<<endl;
                }
        }

主要方法

    int main()
    {
    ini();
    int t,N,i,j,Q,buff,k=0;
    char str[5001];
    scanf("%d",&t);
    map <string ,int > M;
    map <string , int >::iterator ii;
    for(;t--;)
    {
        scanf("%d%d",&N,&Q);
        scanf(" %s",str);
        for(i=0;str[i];i++)
            {
                char temp[5001];
                k=0;
                cout<<str[i]<<endl;
                for(j=i;str[j];j++)
                    {
                        temp[k]=(char)str[j];
                        k++;
                        temp[k]='';
                        string e(temp);
                        M[e]++;
                        cout<<j<<endl;
                    }
            }
        for(ii=M.begin();ii!=M.end();++ii)
                F[ii->second]++;
        F2[N]=F[N]%MOD;
        for(i=N;i>=1;i--)
            if(F[i])
                for(j=i-1;j>=1;j--)
                    F2[j]=(F[j]+((long long)F[i]%MOD*C(F[i],j)%MOD)%MOD)%MOD;
        for(i=0;i<Q;i++)
           {
                scanf("%d",&buff);
                printf("%dn",F2[buff]);
            }
        }
        return 0;
    }

注意

int F[5001],F2[5001];

也在全球范围内声明。

根据要求:

#include <iostream>
#include <string>
#include <map>
#define MOD 10
using namespace std;
int C( int a, int b ){
    return 5;
}
int F[5001],F2[5001];
int main()
    {
    int t,N,i,j,Q,buff,k=0;
    string str(5001, ' ');
    cin >> t;//scanf("%d",&t);
    cin.ignore( 256, 'n' );
    map <string ,int > M;
    map <string , int >::iterator ii;
    for(;t--;)
    {
        cin >> N;
        cin.ignore( 256, 'n' );
        cin >> Q;
        cin.ignore( 256, 'n' );
        //scanf(" %s",str);
        getline(cin,str);
        for(i=0;str[i];i++)
            {
                char temp[5001];
                k=0;
                cout<<str[i]<<endl;
                for(j=i;str[j];j++)
                    {
                        temp[k]=(char)str[j];
                        k++;
                        temp[k]='';
                        string e(temp);
                        M[e]++;
                        cout<<j<<endl;
                    }
            }
        for(ii=M.begin();ii!=M.end();++ii)
                F[ii->second]++;
        F2[N]=F[N]%MOD;
        for(i=N;i>=1;i--)
            if(F[i])
                for(j=i-1;j>=1;j--)
                    cout << "hello";F2[j]=(F[j]+((long long)F[i]%MOD*C(F[i],j)%MOD)%MOD)%MOD;
        for(i=0;i<Q;i++)
           {
                scanf("%d",&buff);
                printf("%dn",F2[buff]);
            }
        }
        return 0;
    }

出于测试目的,由于没有给出MODC定义,因此MOD我使用了一个常量int,并C一个接收这些参数并简单地返回值的空函数。

我没有使用 scanf ,而是使用 cin 作为输入,后来cin.ignore()清除输入缓冲区,这样它就不会跳过下一个cin。将str更改为键入 string 。用于getline获取字符串的输入,因为这从输入cin读取 enitre 行。这就是修改。

        for(i=0;str[i];i++)
        {
            for(j=0;str[j+i];j++)
            {
                M[str.substr(j,i+1)]++;
            }
        }

用这个替换内部两个for循环,并检查它是否崩溃。如果仍然意味着您可能正在Windows上运行此程序。在这种情况下,请使用此。

        for(i=0;str[i];i++)
        {
            for(j=0;str[j+i];j++)
            {
                std::string sstr = str.substr(j,i+1);
                if ( M.find ( sstr ) == M.end() ){
                      M.insert( std::make_pair ( sstr , 0 ) ) ;
                }
                else
                M[str.substr(j,i+1)]++;
            }
        }