Недопустимая проблема преобразования в C ++ - PullRequest
2 голосов
/ 05 марта 2009

У меня есть следующий фрагмент:

string base= tag1[j];

Это дает недопустимую ошибку преобразования.

Что не так с моим кодом ниже? Как я могу преодолеть это.

Полный код здесь:

#include <iostream>
#include <vector>
#include <fstream>
#include <sstream>
#include <time.h>
using namespace std;


int main  ( int arg_count, char *arg_vec[] ) {
    if (arg_count < 3 ) {
        cerr << "expected one argument" << endl;
        return EXIT_FAILURE;
    }

    // Initialize Random Seed
    srand (time(NULL));

    string line;
    string tag1     = arg_vec[1];
    string tag2     = arg_vec[2];

    double SubsRate = 0.003;
    double nofTag   = static_cast<double>(atoi(arg_vec[3])); 

    vector <string> DNA;
      DNA.push_back("A");
      DNA.push_back("C");
      DNA.push_back("G");
      DNA.push_back("T");


      for (unsigned i=0; i < nofTag ; i++) {

          int toSub = rand() % 1000 + 1;

          if (toSub <= (SubsRate * 1000)) {
              // Mutate
              cout << toSub << " Sub" << endl;

              int mutateNo = 0;
              for (int j=0; j < tag1.size(); j++) {

                  mutateNo++;


                  string base = tag1[j]; // This fail

                  int dnaNo = rand() % 4;

                  if (mutateNo <= 3) {
                     // Mutation happen at most at 3 position
                        base = DNA[dnaNo];
                  }

                  cout << tag1[j] << " " << dnaNo << " " << base  <<  endl;
                  //cout << base;

              }
               cout << endl;

          }
          else {
              // Don't mutate
              //cout << tag1 << endl;
          }

      }
    return 0;
}

Почему я получаю недопустимое преобразование из char в const char* при циклическом переносе строки?

Ответы [ 5 ]

7 голосов
/ 05 марта 2009

std::string operator [] возвращает один символ. Строка не может быть создана одним символом.

Использование:

string base = string( 1, tag1[j] ) вместо

4 голосов
/ 05 марта 2009

Измените его на

char base = tag1[j];
3 голосов
/ 05 марта 2009

string tag1 = arg_vec [1];

tag1 - строковый литерал.

string base = tag1[j]; инициализируется с char вместо char *.

Попробуйте, char base = tag1[j];

2 голосов
/ 05 марта 2009

Для string не существует конструктора, который бы занимал всего char (что и есть tag1[j]). У вас есть пара вариантов:

string base;  // construct a default string
base  = tag1[j]; // set it to a char (there is an 
                 //   assignment from char to string, 
                 //   even if there's no constructor

или

string base( 1, tag1[j]);  // create a string with a single char 

Или, как Джош упомянул , вы можете определить base как char, так как вы все равно не выполняете никаких строковых операций над ним. Если вы решите сделать это, вам нужно изменить DNA на vector<char> (и изменить инициализацию DNA на использование символов вместо строк).

1 голос
/ 05 марта 2009

Одна проблема заключается в том, что в сообщении об ошибке говорится, что программа ожидает один аргумент, когда на самом деле требуется два. Вы, вероятно, должны следовать соглашениям Unix и показать требуемое использование (или вместо этого):

if (arg_count != 3) {
    cerr << "Usage: " << arg_vec[0] << " tag1 tag2";
    return EXIT_FAILURE;
}

Имена 'argc' и 'argv' очень условны (и единственная серьезная альтернатива, которую я видел, это 'ac' и 'av'). Возможно, стоит придерживаться этого.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...