|
0 / 0 / 0
Регистрация: 24.11.2010
Сообщений: 17
|
|
ошибка преобразования char01.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
|
|
| 01.12.2010, 04:28 | |
|
Ответы с готовыми решениями:
24
Ошибка "error C2446: :: нет преобразования "int" в "char *" Преобразования char в double Преобразования с char в string |
|
4866 / 3287 / 468
Регистрация: 10.12.2008
Сообщений: 10,570
|
|||||||||||||||||||||||||||||||||||||
| 02.12.2010, 23:09 | |||||||||||||||||||||||||||||||||||||
|
там этот do ... while() начинается, а i и j не инициализируются нулями, то есть они остались с предыдущего цикла
внутри цикла условие такое, что когда один из массивов закончится, то значения из него будут продолжать сравниваться, соответственно, если условие сработает, будет выход за край
отступы очень важны, это не просто так делают
0
|
|||||||||||||||||||||||||||||||||||||
|
0 / 0 / 0
Регистрация: 24.11.2010
Сообщений: 17
|
|||||||||||
| 05.12.2010, 02:31 [ТС] | |||||||||||
|
Спасибо, уже лучше, частично заработало(сортирует пузырьком оба файла). но вот слияние не хочет сделать...
в цикле do while вроде бы все долдно быть нормально, ибо аналогичная прога для массива чисел работает. на данный момент:
Добавлено через 42 минуты и если поменять, как вы сказали, здесь
и пузырек с такими циклами работает. если можно, подскажите, как исправть ошибку, а не только строчку, где она содержится.потому как не всегда понятно, что исправлять следует.
0
|
|||||||||||
|
4866 / 3287 / 468
Регистрация: 10.12.2008
Сообщений: 10,570
|
|||||||||||||||||||||
| 05.12.2010, 09:48 | |||||||||||||||||||||
|
не должно быть различий в размерах массивов, либо везде 80, либо везде 81
в результате получается перекос, если в in попадёт 80 нормальных символов, то 81 делается нуль-символом in[80]='\0'; - это 81й символ прикинь, в строку, где может быть 79 символов, копируется 80 символов, 80й попадает на место нуль-символа, это значит, что функцию сравнения нельзя применять к такой строке, потому что функция сравнения strcmp() для обеих строк концы определяет по нуль-символам в них это значит, что при сравнении, если она дойдёт до конца массива, она выйдет за его пределы и будет дальше сравнивать, пока за его пределами не встретит байт со значением равным нулю поэтому везде либо 80, либо 81, но не по-разному
из этого же цикла pa[i], представь, если i == 100, это будет обращение к 101му элементу, в то время как char*pa[100]; содержит только сто элементов
ты когда, например, прочитала три строки из файла, у тебя 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 | |||||||||||||||||||||||
но сортировка всё равно должна выглядеть
для этого можно специально вывести kolstrA перед теми циклами, где оно задаёт границу
меньше, чем сто строк? а ты думаешь, если он прочитал десять строк, там не будет того же самого? будет, только обращаться он будет не к 101й строке, а к 11й, которой там нет поменяешь всё на 80 и всё
а pa[kolstrA] элемента там нет, pb[kolstrB] элемента тоже нет а если их там нет, зачем они сравниваются ? а равные строки вообще не сохраняются
0
|
|||||||||||||||||||||||
| 05.12.2010, 22:54 | |
|
Нет преобразования int в char* функция для преобразования __time64_t в char *
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
сукцессия 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
Что ДЕС/ СМО умеет считать напрямую:
Конфликты за ресурсы (очереди, узкие места). Несколько типов агентов (повара, учителя, рабочие, пациенты) претендуют на один ресурс (лифт, вход, коридор,. . .
|