Перейти из форума на сайт.

НовостиФайловые архивы
ПоискАктивные темыТоп лист
ПравилаКто в on-line?
Вход Забыли пароль? Первый раз на этом сайте? Регистрация
Компьютерный форум Ru.Board » Компьютеры » Прикладное программирование » Задачи по C/С++

Модерирует : ShIvADeSt

 Версия для печати • ПодписатьсяДобавить в закладки
Страницы: 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 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389

Открыть новую тему     Написать ответ в эту тему

de_lirium

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Тема создана для накопления реализаций типовых задач на С/С++.
Прежде чем публиковать своё условие задачи, убедитесь, что её решение (или решение очень похожей задачи) в теме и полезных ссылках отсутствует (например воспользуйтесь ссылкой Версия для печати вверху справа страницы и поищите в ней).
Постарайтесь как можно полнее сформулировать постановку задачи (чтобы тому, кто решит вам помочь, не приходилось тратить своё время ещё и на выпытывание у вас деталей условия; если вам не понятно, как это сделать - постарайтесь представить, что эта программа у вас уже есть, и "поработать" с ней - вот все детали, которые при этом придут в голову, с большой вероятностью должны быть в условии задачи).
Если вы уже пытались сделать эту задачу, но у вас не получилось и вы хотите довести дело до конца - обязательно выложите результат своей попытки, предварительно убедившись, что ваш код компилируется.

Вопросы по технологиям лучше задавать тут.

Прежде чем просить помощи в задании...
Если позарез надо и вы даже готовы заплатить

Если вам вдруг не отвечают или ответ вас не устраивает, и вообще полезно прочитать всем спрашивающим.

Полезные ссылки:
 
C++: в том числе и решения задач (eng)
задачи на C
 
Проверить свою задачку можно:
Онлайн-компилятором Visual C++
godbolt
Wandbox
Одним из онлайн-компиляторов на ideone.com

Всего записей: 28 | Зарегистр. 23-07-2004 | Отправлено: 02:14 20-12-2004 | Исправлено: Daniyar91, 19:25 27-09-2017
Prober

Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Eterington

Цитата:
весь гугл облазил, там нет того, что мне нужно

Не знаю, где ты лазил...
Набрав в яндексе "перемножение матриц на си", получил почти 6 тыс. ссылок, на первой же странице оказалось минимум 2 нужных исходника с пояснениями.

Всего записей: 680 | Зарегистр. 01-11-2006 | Отправлено: 15:50 27-12-2009
alex1307

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
DeadStrelok
 
Спасибо!

Всего записей: 9 | Зарегистр. 26-12-2009 | Отправлено: 16:56 27-12-2009
Eterington

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
МНЕ-ТО нужно , чтобы именно через простые операторы
я уже сделал, но проверить не могу, может кто-нибудь глянет:
 
#include <stdio.h>  
#include <stdlib.h>  
#include <conio.h>  
 
int main()  
{  
int i,j,k,m1,n1,n2,m2;  
float a[100][100],b[100][100],c[100][100]={0};            
 
//srand(time(NULL));                              
printf("vvedite m1,n1,m2,n2,gde n1=m2:  ");  
scanf("%d%d%d%d",&m1,&n1,&m2,&n2);                            
printf("matrix a\n");                                                    
for (i = 0; i < m1; i++) {    
for ( k=0; k<n1; k++)  
printf("%6.2f ",a[i][k]=1+20*(float)rand()/32768);  
puts("\n");}  
 
printf("matrix b\n");  
for (k = 0; k < m2; k++) {  
for ( j=0; j<n2; j++)  
printf("%6.2f ",b[k][j]=1+20*(float)rand()/32768);  
puts("\n");}
 
printf("matrix c=a*b");  
 
 
for (i=0; i<m1; i++)  {  
  for (j=0; j<n2; j++)  {  
    c[i][j]=0;  
    for (k=0; k<m2; k++) c[i][j]=c[i][j]+a[i][k]*b[k][j];  
    }  
  }
printf("%6.2f ",c[i][j]);  
puts("\n");  
 
 
getch();
return 0;
}  

Всего записей: 11 | Зарегистр. 20-12-2009 | Отправлено: 17:17 27-12-2009
KChernov



Silver Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Eterington
Чё, компилятор уже сломался?

Всего записей: 2471 | Зарегистр. 20-04-2004 | Отправлено: 08:18 28-12-2009
Eterington

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
да чё-то не проверяет

Всего записей: 11 | Зарегистр. 20-12-2009 | Отправлено: 10:53 28-12-2009
SIgor33

Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Возникла проблема : Почему то из файла считывается только одна запись, хотя их там несколько штук =(((
Подскажите пожалуйста в чём проблема ?
 
Подробнее...

Всего записей: 652 | Зарегистр. 03-03-2009 | Отправлено: 12:00 28-12-2009
Eugenio91

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
помогите с переводом программы под borland
/* mla1d.f -- translated by f2c (version 20000817).
   You must link the resulting object file with the libraries:
        -lf2c -lm   (in that order)
*/
 
#include "f2c.h"
 
/* Table of constant values */
 
static integer c__0 = 0;
static integer c__1 = 1;
 
/* Subroutine */ int mla1d_c(doublereal *a, integer *m, integer *n,
        integer *ma, integer *na, integer *m1, integer *m2, integer *m3,
        integer *iflag, integer *izrov, integer *iposv, integer *l1,
        integer *l2, integer *l3)
{
    /* Initialized data */
 
    static doublereal eps = 1e-6;
    static doublereal zero = 0.;
    static doublereal one = 1.;
 
    /* System generated locals */
    integer a_dim1, a_offset, i__1, i__2;
 
    /* Local variables */
    static doublereal bmax;
    static integer i__, k;
    extern /* Subroutine */ int mla1d1_c(doublereal *, integer *, integer *,
            integer *, integer *, integer *, integer *, integer *,
            doublereal *),
            mla1d2_c(doublereal *, integer *, integer *, integer *,
            integer *, integer *, integer *, integer *, integer *,
            doublereal *),
            mla1d3_c(doublereal *, integer *, integer *, integer *,
            integer *, integer *, integer *);
    static integer k1, n1;
    static doublereal q1;
    static integer m11, m12, kh, ip, ir, kp, is, im1, ip1, nl1, nl2;
 
#define a_ref(a_1,a_2) a[(a_2)*a_dim1 + a_1]
 
    /* Parameter adjustments */
    --iposv;
    --izrov;
    --l3;
    --l2;
    --l1;
    a_dim1 = *ma;
    a_offset = 1 + a_dim1 * 1;
    a -= a_offset;
 
    /* Function Body */
    *iflag = 0;
    if (*m == *m1 + *m2 + *m3) {
        goto L1;
    }
    *iflag = 65;
    goto L250;
 L1:if (*m1 + *m3 != 0) {
        goto L10;
    }
    *iflag = 67;
    goto L250;
L10:
    nl1 = *n;
    i__1 = *n;
    for (k = 1; k <= i__1; ++k) {
        l1[k] = k;
        izrov[k] = k;
/* L20: */
    }
    nl2 = *m;
    i__1 = *m;
    for (i__ = 1; i__ <= i__1; ++i__) {
        if (a_ref(i__ + 1, 1) >= zero) {
            goto L30;
        }
        *iflag = 66;
        goto L250;
L30:
        l2[i__] = i__;
        iposv[i__] = *n + i__;
/* L40: */
    }
    if (*m2 == 0) {
        goto L55;
    }
    i__1 = *m2;
    for (i__ = 1; i__ <= i__1; ++i__) {
        l3[i__] = 1;
/* L50: */
    }
L55:
    ir = 0;
    n1 = *n + 1;
    m11 = *m1 + 1;
    if (*m2 + *m3 == 0) {
        goto L230;
    }
    ir = 1;
    i__1 = n1;
    for (k = 1; k <= i__1; ++k) {
        q1 = zero;
        i__2 = *m;
        for (i__ = m11; i__ <= i__2; ++i__) {
            q1 += a_ref(i__ + 1, k);
/* L60: */
        }
        a_ref(*m + 2, k) = -q1;
/* L70: */
    }
L80:
    i__1 = *m + 1;
    mla1d1_c(&a[a_offset], ma, na, &i__1, &l1[1], &nl1, &c__0, &kp, &bmax);
    if (bmax <= eps && a_ref(*m + 2, 1) < -eps) {
        goto L90;
    }
    if (bmax <= eps && a_ref(*m + 2, 1) <= eps) {
        goto L100;
    }
    goto L150;
L90:
    *iflag = 68;
    goto L250;
L100:
    m12 = *m1 + *m2 + 1;
    if (m12 > *m) {
        goto L120;
    }
    i__1 = *m;
    for (ip = m12; ip <= i__1; ++ip) {
        ip1 = ip;
        if (iposv[ip] != ip + *n) {
            goto L110;
        }
        mla1d1_c(&a[a_offset], ma, na, &ip1, &l1[1], &nl1, &c__1, &kp, &bmax);
        if (bmax > zero) {
            goto L155;
        }
L110:
        ;
    }
L120:
    ir = 0;
    --m12;
    if (*m1 + 1 > m12) {
        goto L230;
    }
    i__1 = m12;
    for (i__ = m11; i__ <= i__1; ++i__) {
        im1 = i__ - *m1;
        if (l3[im1] != 1) {
            goto L140;
        }
        i__2 = n1;
        for (k = 1; k <= i__2; ++k) {
            a_ref(i__ + 1, k) = -a_ref(i__ + 1, k);
/* L130: */
        }
L140:
        ;
    }
    goto L230;
L150:
    mla1d2_c(&a[a_offset], m, n, ma, na, &l2[1], &nl2, &ip, &kp, &q1);
    if (ip != 0) {
        goto L160;
    }
    *iflag = 68;
    goto L250;
L155:
    ip = ip1;
L160:
    i__1 = *m + 1;
    mla1d3_c(&a[a_offset], ma, na, &i__1, n, &ip, &kp);
    if (iposv[ip] < *n + *m1 + *m2 + 1) {
        goto L195;
    }
    i__1 = nl1;
    for (k = 1; k <= i__1; ++k) {
        k1 = k;
        if (l1[k] == kp) {
            goto L180;
        }
/* L170: */
    }
L180:
    --nl1;
    i__1 = nl1;
    for (is = k1; is <= i__1; ++is) {
        l1[is] = l1[is + 1];
/* L190: */
    }
    goto L200;
L195:
    if (iposv[ip] < *n + *m1 + 1) {
        goto L220;
    }
    kh = iposv[ip] - *m1 - *n;
    if (l3[kh] == 0) {
        goto L220;
    }
    l3[kh] = 0;
L200:
    a_ref(*m + 2, kp + 1) = a_ref(*m + 2, kp + 1) + one;
    *m2 = *m + 2;
    i__1 = *m2;
    for (i__ = 1; i__ <= i__1; ++i__) {
        a_ref(i__, kp + 1) = -a_ref(i__, kp + 1);
/* L210: */
    }
L220:
    is = izrov[kp];
    izrov[kp] = iposv[ip];
    iposv[ip] = is;
    if (ir != 0) {
        goto L80;
    }
L230:
    mla1d1_c(&a[a_offset], ma, na, &c__0, &l1[1], &nl1, &c__0, &kp, &bmax);
    if (bmax <= zero) {
        goto L250;
    }
    mla1d2_c(&a[a_offset], m, n, ma, na, &l2[1], &nl2, &ip, &kp, &q1);
    if (ip != 0) {
        goto L240;
    }
    *iflag = 67;
    goto L250;
L240:
    mla1d3_c(&a[a_offset], ma, na, m, n, &ip, &kp);
    goto L220;
L250:
    return 0;
} /* mla1d_c */
 
#undef a_ref

Всего записей: 4 | Зарегистр. 28-12-2009 | Отправлено: 21:43 28-12-2009
akaGM

Platinum Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Eugenio91
блин... что ты по форуму скачешь?
всё там под борландом работает, если аккуратно скачать/подключить f2c.h и соответствующие библиотеки
 
поставь в самом начале две строчкм, и будет тебе щасье:
 
typedef double doublereal;
typedef int integer;
 
---
NB
 
гы-гы
f2c-конвертор отработал...

Всего записей: 24056 | Зарегистр. 06-12-2002 | Отправлено: 21:46 28-12-2009 | Исправлено: akaGM, 21:53 28-12-2009
krodion

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Помогите пожалуйста решить задачку:
1)В одномерном массиве состоящем из n вещественных элементов, вычислить сумму элементов массива и среднее арифметическое элементов массива, значение суммы и среднего значения записать  в файл..
2)в одномерном массиве состоящем из n вещественных элементов:
а)отсортировать элементы массива по убыванию,  
б)записать сортированные элементы в файлюю

Всего записей: 6 | Зарегистр. 16-12-2009 | Отправлено: 22:34 28-12-2009 | Исправлено: krodion, 22:36 28-12-2009
SIgor33

Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Eugenio91
про тэг more прочтиа то слишком длино получаетс и пользуйся на здоровье

Всего записей: 652 | Зарегистр. 03-03-2009 | Отправлено: 13:16 29-12-2009
DeadStrelok



Junior Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
krodion
1)Подробнее...
Файл создастся в корне диска С, путь можешь сам указать...
 
2)Подробнее...

Всего записей: 40 | Зарегистр. 01-12-2009 | Отправлено: 09:41 30-12-2009 | Исправлено: DeadStrelok, 10:08 30-12-2009
utwo



Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Всем, привет! С праздниками!
 
Элeмeнт дeрeвa coдeржит либo дaнныe (cтрoкa oгрaничeннoй
длины), либo укaзaтeли нa прaвoe и лeвoe пoддeрeвья. cтрoки в
дeрeвe упoрядoчeны. Нaпиcaть функцию включeния нoвoй cтрoки.
oбрaтить внимaниe нa тo, чтo элeмeнт c укaзaтeлями нe coдeржит
дaнных, и при включeнии нoвoй вeршины вeршину c дaнными
cлeдуeт зaмeнить нa вeршину c укaзaтeлями.
 

 
Прoгрaммa дoлжнa coдeржaть функцию oбхoдa дeрeвa c вывoдoм
eгo coдeржимoгo, функцию дoбaвлeния вeршины дeрeвa
(ввoд), a тaкжe укaзaнную в вaриaнтe функцию.
 
Спасибо за любой ответ!

Всего записей: 17 | Зарегистр. 25-04-2008 | Отправлено: 15:54 07-01-2010 | Исправлено: utwo, 17:00 07-01-2010
Luzyshka

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
                                  ПОМОГИТЕ!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
Пошук точки екстремуму нелінійної функції 1-єї змінної на заданому відрізку за методом Фібоначі.

Всего записей: 1 | Зарегистр. 08-01-2010 | Отправлено: 19:35 08-01-2010
AkordMinor

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
Подскажите пожалуйста, как считать текст из файла, минуя пробелы и знаки табуляции, в массив символов?

Всего записей: 4 | Зарегистр. 07-12-2009 | Отправлено: 22:13 08-01-2010
stasnewar

Junior Member
Редактировать | Профиль | Сообщение | ICQ | Цитировать | Сообщить модератору
Парни, помогите!как программно перезапустить программу, т.е. функцию main(). язык Си.

Всего записей: 79 | Зарегистр. 01-03-2009 | Отправлено: 17:07 09-01-2010
realtion



Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
utwo
Интерфейс класса, с которым ты должен работать
должен выглядеть приблизительно так:
 
class tree
{
tree* left; //указатель на левую вершину
tree* right; //указатель на правую вершину
char* name; //данные, содержащиеся в вершине
public:
tree(char*);
void Add(char*); //Добавить новую вершину
void Obhod(); //Обход дерева с выводом
//Может еще какие-нибуть функции
};
 
Конструктор
tree::tree(char* pName)
{
name = new char[lenght(pName)];
}
Насколько я понял, узел дерева не должен содержать данных.
Данные должны находиться в листьях, поэтому можно, к примеру,
при добавлении новой вершины, эту новую вершину делать по умолчанию
правым потомком, а данные, что находились в самой вершине переносить в левый потомок. К примеру так:
void tree::Add(char* pName)
{
right = new tree(pName);
left = new tree(name);
delete name;
}
Обход будет осуществляться приблизительно так:
void tree::Obhod()
{
  if(left!=NULL&&right!=NULL){
    left.Obhod();
    right.Obhod();
  }
  else{
    cin<<*name;
  }
}
 
Добавлено:
SIgor33
Как-то у меня возникала такая проблема.
Я её решил использованием функции вроде getline,
в которой указывается из какого потока читать, сколько символов максимально может быть строка и какой символ считается концом строки (по умолчанию символ конца строки \0 считается концом строки ).

Всего записей: 20 | Зарегистр. 09-01-2010 | Отправлено: 09:52 11-01-2010
SAV83



Junior Member
Редактировать | Профиль | Сообщение | ICQ | Цитировать | Сообщить модератору
Здравствуйте форумчане.
Не могу найти информации как написать перехват потока.
если точнее:
Есть например access.log который пишет squid.
Задача: нужна программа которая постоянно будет висеть и будет построково выводить, к примеру на экран все, что пишется в lоg, при чем, при запуске с каким-либо ключем, log не будет писаться.
 
делал решение наподобии через pipe канал, но возникли другие задачи и данное решение уже не устраивает.
Подсобите ПЛЗ! направьте;)

Всего записей: 66 | Зарегистр. 17-01-2007 | Отправлено: 14:35 11-01-2010
realtion



Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
SAV83
Незнаю как организовать перехват потока, но на первый взгляд такую задачу можно попробывать решить реализовав паттерн Наблюдатель (см. паттерны проектирования Гамма, Хэлмf)

Всего записей: 20 | Зарегистр. 09-01-2010 | Отправлено: 19:55 13-01-2010
ValidolX

Advanced Member
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
SAV83
если кодировать используя WinAPI - используйте следующие API (мониторинг изменений в файловой системе)
 
FindFirstChangeNotification()
FindNextChangeNotification()
 
есть обертка, правда на Паскале

Всего записей: 1710 | Зарегистр. 22-07-2001 | Отправлено: 21:07 13-01-2010
MazaiZ2008

Newbie
Редактировать | Профиль | Сообщение | Цитировать | Сообщить модератору
помогите плиззз с лабой))
с клавиатуры введено целое положительное число (десятиричная система ).нужно перевести в в систему исчисления с заданным основанием n (n<10)

Всего записей: 4 | Зарегистр. 23-03-2008 | Отправлено: 22:51 13-01-2010
Открыть новую тему     Написать ответ в эту тему

Страницы: 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 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389

Компьютерный форум Ru.Board » Компьютеры » Прикладное программирование » Задачи по C/С++


Реклама на форуме Ru.Board.

Powered by Ikonboard "v2.1.7b" © 2000 Ikonboard.com
Modified by Ru.B0ard
© Ru.B0ard 2000-2024

BitCoin: 1NGG1chHtUvrtEqjeerQCKDMUi6S6CG4iC

Рейтинг.ru