Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск  
 
 
Рейтинг 4.57/14: Рейтинг темы: голосов - 14, средняя оценка - 4.57
0 / 0 / 0
Регистрация: 24.11.2010
Сообщений: 17

ошибка преобразования char

01.12.2010, 04:28. Показов 3398. Ответов 24
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
помогите найти ошибку(или исправить):
#include<iostream>
#include<string.h>
#include<conio.h>
#include<stdio.h>
#include<stdlib.h>
using namespace std;
typedef char *pChar;
typedef char **ppChar;

FILE*out1,*out2,*out3;
void main()
{out1=fopen("text1.txt","r");
out2=fopen("text2.txt","r");
out3=fopen("text3.txt","w");
int i,j,m,n,kolstrA,kolstrB;
char in[80];
char an[80];
char*pa[100];
char*pb[100];
char*pc[100];
char*pk[100];
char a[100][80];
char b[100][80];
char c[200][80];


for (kolstrA=0;kolstrA<100;kolstrA++)
{if(fgets(in,80,out1)==NULL)
{break;};
in[80]='\0';
strncpy(a[kolstrA],in,80);};
fclose(out1);
for(kolstrB=0;kolstrB<100;kolstrB++)
{if(fgets(an,80,out2)==NULL)
{break;};
an[80]='\0';
strncpy(b[kolstrB],an,80);};
fclose(out2);

for(i=0;i<=kolstrA;i++)
{pa[i]=a[i];};
for(j=0;j<=kolstrB;j++)
{pb[j]=b[j];};
for(m=0;m<=(kolstrA+kolstrB);m++)
{pc[m]=c[m];};
i=0;
j=0;
m=0;
for(i=0;i<=kolstrA-2;i++)
for(j=i+1;j<=kolstrA-1;j++)
{if(strcmp(pa[i],pa[j])<0)
{strcpy(pk,pa[i]);
strcpy(pa[i],pa[j]);
strcpy(pa[j],pk);};};
for(i=0;i<=kolstrB-2;i++)
for(j=i+1;j<=kolstrB-1;j++)
{if(strcmp(pb[i],pb[j])<0)
{strcpy(pk,pb[i]);
strcpy(pb[i],pb[j]);
strcpy(pb[j],pk);};};
do
{if(strcmp(pa[i],pb[j])<0)
{pc[m]=pa[i];
i=i+1;
m=m+1;}
else
{pc[m]=pb[j];
j=j+1;
m=m+1;};}
while(i<kolstrA||j<kolstrB);
while(j<=kolstrB)
{pc[m]=pb[j];
j=j+1;
m=m+1;};
while(i<=kolstrA)
{pc[m]=pa[i];
i=i+1;
m=m+1;};
cout<<"rezultat"<<"\n";
for(m=0;m<(kolstrA+kolstrB);m++)
{printf("%s\n",pc[m]);};
return;
}

error C2664: strcpy: невозможно преобразовать параметр 2 из 'char *[100]' в 'const char *'
Типы, на которые указывают указатели, не связаны; для преобразования требуется reinterpret_cast, приведение в стиле С или приведение в стиле функции
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
01.12.2010, 04:28
Ответы с готовыми решениями:

Ошибка "error C2446: :: нет преобразования "int" в "char *"
Ошибка: &quot;error C2446: :: нет преобразования &quot;int&quot; в &quot;char *&quot; Когда нажимаю двойным кликом на ошибку меня перекидывает в файл...

Преобразования char в double
Здравствуйте, я использую visual studio 15 и при компиляции следующего кода выводиться ошибка преобразования: #include...

Преобразования с char в string
Помогите исправить и переделать чтобы использовать с string а не с char.Очень прошу:wall::help: #include &lt;iostream&gt; #include...

24
4866 / 3287 / 468
Регистрация: 10.12.2008
Сообщений: 10,570
02.12.2010, 23:09
Студворк — интернет-сервис помощи студентам
там этот do ... while() начинается, а i и j не инициализируются нулями, то есть они остались с предыдущего цикла
внутри цикла условие такое, что когда один из массивов закончится, то значения из него будут продолжать сравниваться, соответственно, если условие сработает, будет выход за край

Цитата Сообщение от student101
А где неправильные границы циклов?
C
1
for(kolstrB=0;kolstrB<100;kolstrB++)
правильно

C
1
for(i=0;i<=kolstrA;i++)
неправильно

C
1
for(m=0;m<=(kolstrA+kolstrB);m++)
неправильно

C
1
for(i=0;i<=kolstrB-2;i++)
вот эффект, здесь условие правильное, но оно неправильно записано

C
1
for (i = 0; i < kolstrB - 1; i++)
вот так оно должно выглядеть

C
1
for (i = 0; i + 1 < kolstrB; i++)
или так

C
1
2
    while (j <= kolstrB) {
        pc[m] = pb[j];
вот ошибка, идёт обращение к pb[j] элементу, такого нет, когда j == kolstrB

отступы очень важны, это не просто так делают
0
0 / 0 / 0
Регистрация: 24.11.2010
Сообщений: 17
05.12.2010, 02:31  [ТС]
Спасибо, уже лучше, частично заработало(сортирует пузырьком оба файла). но вот слияние не хочет сделать...
в цикле do while вроде бы все долдно быть нормально, ибо аналогичная прога для массива чисел работает.
на данный момент:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
#include<iostream>
#include<string.h>
#include<conio.h>
#include<stdio.h>
#include<stdlib.h>
using namespace std;
 
 
FILE*out1,*out2,*out3;
void main()
{out1=fopen("text1.txt","r");
out2=fopen("text2.txt","r");
int i,j,m,kolstrA,kolstrB;
char in[81];
char an[81];
char*pa[100];
char*pb[100];
char*pc[200];
char pk[80];
char a[100][80];
char b[100][80];
char c[200][80];
 
 
for (kolstrA=0;kolstrA<100;kolstrA++)
  {if(fgets(in,81,out1)==NULL)
     {break;};
      in[80]='\0';
      strncpy(a[kolstrA],in,80);};
 fclose(out1);
for(kolstrB=0;kolstrB<100;kolstrB++)
     {if(fgets(an,81,out2)==NULL)
       {break;};
       an[80]='\0';
       strncpy(b[kolstrB],an,80);};
 fclose(out2);
;
for(i=0;i<=kolstrA;i++)
  {pa[i]=a[i];};
for(j=0;j<=kolstrB;j++)
  {pb[j]=b[j];};
for(m=0;m<=(kolstrA+kolstrB);m++)
  {pc[m]=c[m];};
i=0;j=0;
 
for(i=0;i<=kolstrA-2;i++)
  for(j=i+1;j<=kolstrA-1;j++)
 
 {if(strcmp(pa[i], pa[j]) < 0) {
        char *p = pa[i];
        pa[i] = pa[j];
        pa[j] = p;
};}
 
for(i=0;i<=kolstrB-2;i++)
  for(j=i+1;j<=kolstrB-1;j++)
   {if(strcmp(pb[i],pb[j])<0)
 {
        char *p = pb[i];
        pb[i] = pb[j];
        pb[j] = p;
};}
 
 i=0;j=0;m=0;
do
{if(strcmp(pa[i],pb[j])<0)
  {strcpy(pc[m],pa[i]);
  i=i+1;
  m=m+1;}
else
 if(strcmp(pa[i],pb[j])>0)
  {strcpy(pc[m],pb[j]);
   j=j+1;
   m=m+1;};}
while(i<kolstrA||j<kolstrB);
 
while(j<kolstrB)
  {strcpy(pc[m],pb[j]);
   j=j+1;
   m=m+1;};
while(i<kolstrA)
  {strcpy(pc[m],pa[i]);
  i=i+1;
  m=m+1;};
 
cout<<"rezultat"<<"\n";
 for(m=0;m<(kolstrA+kolstrB);m++)
  {printf("%s\n",pc[m]);};
  return;
  }
что не так?

Добавлено через 42 минуты
и если поменять, как вы сказали, здесь
C++
1
2
3
4
5
6
for(i=0;i<=kolstrA;i++)
 {pa[i]=a[i];};
for(j=0;j<=kolstrB;j++)
 {pb[j]=b[j];};
for(m=0;m<=(kolstrA+kolstrB);m++)
 {pc[m]=c[m];};
то сразу возникают ошибки указателей.
и пузырек с такими циклами работает.

если можно, подскажите, как исправть ошибку, а не только строчку, где она содержится.потому как не всегда понятно, что исправлять следует.
0
4866 / 3287 / 468
Регистрация: 10.12.2008
Сообщений: 10,570
05.12.2010, 09:48
не должно быть различий в размерах массивов, либо везде 80, либо везде 81

C
1
2
3
4
if(fgets(in,81,out1)==NULL)
     {break;};
      in[80]='\0';
      strncpy(a[kolstrA],in,80);};
в a[] все строки имеют длину 80, in же имеет длину 81, это значит, что в a[][] можно записать только 79 символов и последний должен быть нуль-символ, а в in можно записать 80 символов и последний должен быть нуль-символ
в результате получается перекос, если в in попадёт 80 нормальных символов, то 81 делается нуль-символом in[80]='\0'; - это 81й символ

прикинь, в строку, где может быть 79 символов, копируется 80 символов, 80й попадает на место нуль-символа, это значит, что функцию сравнения нельзя применять к такой строке, потому что функция сравнения strcmp() для обеих строк концы определяет по нуль-символам в них

это значит, что при сравнении, если она дойдёт до конца массива, она выйдет за его пределы и будет дальше сравнивать, пока за его пределами не встретит байт со значением равным нулю

поэтому везде либо 80, либо 81, но не по-разному

C
1
for(i=0;i<=kolstrA;i++)
неправильно, нету там столько элементов

C
1
for(i = 0; i < kolstrA; i++)
если kolstrA == 100, то тело цикла выполнится сто раз

из этого же цикла pa[i], представь, если i == 100, это будет обращение к 101му элементу, в то время как char*pa[100]; содержит только сто элементов

C++
1
2
    for (i = 0; i < kolstrA - 1; i++)
        for (j = i + 1; j < kolstrA; j++)
такая сортировка работает неправильно, потому что у тебя логическая ошибка там
ты когда, например, прочитала три строки из файла, у тебя kolstrA равно не три, а два
а зачем тебе два, если у тебя три ?
поэтому тебе нужно либо fgets() перенести в условие цикла из тела, либо при выходе из цикла, когда файл закончился, наращивать kolstrA
0
0 / 0 / 0
Регистрация: 24.11.2010
Сообщений: 17
05.12.2010, 16:53  [ТС]
размеры массивов я поменяла, как вы сказали. про обращение к 100му и 101 элементу-он два отдельных массива сортирует и с этим значениями. в файлах у меня сильно меньше, чем 100 строк.

видимо, в do-while или while где то ошибка, (до этого этапа ведь все работает)но я никак ее не найду.

Добавлено через 7 минут
Если быть точнее, то в каждом файле по 10 строк. для простоты. 100*80-просто максимум. Вряд ли при этом он до 100 дойдет...

Добавлено через 8 минут
И, как ни странно, отдельно взятым файлам с малым числом коротких строк все равно, 80 там или 81...ничего не меняется. Как сделать так, чтобы она хотя бы эти два коротких файла сливала? (Логические ошибки про ста строках не так важны, мне бы хоть что-то сдать)
0
4866 / 3287 / 468
Регистрация: 10.12.2008
Сообщений: 10,570
05.12.2010, 22:54
Цитата Сообщение от accept
ты когда, например, прочитала три строки из файла, у тебя kolstrA равно не три, а два
а зачем тебе два, если у тебя три ?
поэтому тебе нужно либо fgets() перенести в условие цикла из тела, либо при выходе из цикла, когда файл закончился, наращивать kolstrA
это мне показалось, не обращай внимание
но сортировка всё равно должна выглядеть
C++
1
2
    for (i = 0; i < kolstrA - 1; i++)
        for (j = i + 1; j < kolstrA; j++)
важно, чтобы kolstrA было равно количеству строк, которые прочитаны в a[][]
для этого можно специально вывести kolstrA перед теми циклами, где оно задаёт границу

Цитата Сообщение от student101
Вряд ли при этом он до 100 дойдет...
я тебе показал, как такие циклы переделать, переделаешь
меньше, чем сто строк? а ты думаешь, если он прочитал десять строк, там не будет того же самого? будет, только обращаться он будет не к 101й строке, а к 11й, которой там нет

поменяешь всё на 80 и всё

C++
1
strcmp(pa[i],pb[j])<0
в цикле do ... while () идёт обращение к pa[kolstrA], если i выросло до kolstrA
а pa[kolstrA] элемента там нет, pb[kolstrB] элемента тоже нет
а если их там нет, зачем они сравниваются ?
а равные строки вообще не сохраняются

C++
1
while(i<kolstrA||j<kolstrB);
C++
1
while (i < kolstrA && j < kolstrB);
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
05.12.2010, 22:54

Оператор преобразования типа в char*
Всем привет! Вот у меня есть готовый код для класса Complex #include &lt;iostream&gt; #include &lt;cmath&gt; using namespace std; ...

Нет преобразования int в char*
int main() { char s; char* kz = 0; cout &lt;&lt; &quot;Vvedite stroku: &quot;; cin &gt;&gt; s; // строку вводить без пробелов for (int i =...

функция для преобразования __time64_t в char *
Добрый день! Нужна в\у функция а еще лучше пример с ней. Задача примерно выглядит так: дана структура __finddata64_t a; из...

Кривое преобразования с int в char, массивы
Объясните где я сделал ошибку? почему arr и sprob в зависимости от b ++; ведут себя так, и почему так кривая получается строка?b ++;...

Как работают явные преобразования из char[] в int?
Решаю я одну задачу, в ней нужно считать информацию о книгах, вложить это всё в бинарное дерево и выполнять некоторые функции с ними. При...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
25
Ответ Создать тему
Новые блоги и статьи
сукцессия 5
anaschu 26.06.2026
ПЛАН РАЗРАБОТКИ математической модели сукцессии микоризных систем Переход AM → EcM (Endo + ErM) · Шумилов А. С. · ИФХиБПП РАН · Пущино · 2026 . . .
сукцессия 4
anaschu 25.06.2026
Более детализированный план разработки План доработки модели динамики микоризных симбиозов (EcM с гистерезисом) Цель: Реализовать логику переключения между эрикоидным (ErM) и эктомикоризным. . .
сукцессия 3
anaschu 25.06.2026
Примерный план работ по модели
сукцессия 2
anaschu 25.06.2026
параметризировочная калибровочная таблица будущей модели
Многофункциональное здание: как одно здание порождает конфликты требований, которые никто не планировал (мат мет мод 29)
anaschu 23.06.2026
Многофункциональное здание: как одно здание порождает конфликты требований, которые никто не планировал Материалы для обсуждения с МГСУ · 2026 Рисунки внутри приложенного ворд файла. Что за. . .
28. Конкретное развертывание плана номер 1 из поста номер 27
anaschu 22.06.2026
Можно ли из модели получить конкретные строительные требования? Честно — напрямую из текущей модели такие ответы не получить. Но цепочка логики есть, и она не такая длинная. Где разрыв . . .
27. Планы на разработку функциональных требований к строительству внутри модели пищеблока (или не только его?)
anaschu 22.06.2026
Что уже реализовано и даёт конфликты «бесплатно» Самый простой конфликт уже работает — конфликт за ресурс-работника. Заданий больше, чем доступных поваров → очередь в queue1. Это прямое отражение. . .
26. мед мат модель.Какие типы конфликтов функциональных требований можно рассчитать через ДЕС-моделирование (СМО) в AnyLogic?
anaschu 22.06.2026
Что ДЕС/ СМО умеет считать напрямую: Конфликты за ресурсы (очереди, узкие места). Несколько типов агентов (повара, учителя, рабочие, пациенты) претендуют на один ресурс (лифт, вход, коридор,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru