Форум программистов, компьютерный форум CyberForum.ru

Обьясните что не так не могу понять - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ число цифр 3 в пятом представлении числа х http://www.cyberforum.ru/cpp-beginners/thread888247.html
По мат логике дано было задание: число цифр 3 в пятом представлении числа х. На бумаге задачу решил легко.Собственно вот решение Рисунок Надо написать под задачу программу на С++, а я в этом не понимаю.Может кто нибудь написать?
C++ Ввод двумерного массива из файла #include "stdafx.h" #include <stack> #include <iostream> #include <string> #include <algorithm> #include <locale> const int OPEN_VAL = 0; const int CLOSE_VAL = 1; const int START_VAL = -1; http://www.cyberforum.ru/cpp-beginners/thread888246.html
C++ Блок-схема
Доброго дня,всем...Помогите пожалуйста составить 2 простенькие блок-схемы по следующим прогам #include<stdio.h> #include<iostream.h> #include<math.h> #include<stdlib.h> int main() { FILE *vivod; vivod=fopen("D:\lab2_11.txt","w");
C++ Инвентаризация
В инвентарном файле содержатся сведения о том, изделия каких видов продукции и в каком количестве хранились на складе на момент последней инвентаризации. Сведения включают артикул изделия, наименование, единицы измерения, количество. Второй файл содержит сведения о поступлении и отпуске некоторых видов продукции, структура данных здесь дополнена типом операции (поступление или отпуск) и датой ее...
C++ Дана строка символов. Подсчитать общее число вхождений символов http://www.cyberforum.ru/cpp-beginners/thread888208.html
Привет всем. Дана строка символов. Подсчитать общее число вхождений символов .,+ в строку. Помогите реализовать данную программу. Нашел пару вариантов на форуме типа: #include <iostream> #include <iomanip> char * findchar(char * str, char ch){ for(;*str;++str) if (*str==ch) return str; return NULL;
C++ Вывести всех однофамильцев Есть массив обьектов. Надо вывести всех однофамильцев по очереди. я сделал так что береться первый елемент(первый цикл), и проверяеться со всеми остальними(второй цикл), если елемент подошел то помечаем провереным. когда мы сравним первый елемент он будет тоже "помечен" как провереный. И так дальше. А оно сначала выводит однофамильцев, а потом все остальное. #include <fstream> #include... подробнее

Показать сообщение отдельно
Iliasos
0 / 0 / 0
Регистрация: 14.10.2012
Сообщений: 4
02.06.2013, 17:13     Обьясните что не так не могу понять
программа должна менять цвет bmp файла но при запуске выдает ошибку что 2 неразрешимых внешних элемента есть и все я пробовал разобраться но не получилось
коментрарии были даны на паре преподом но они особо не помогли(
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
91
92
93
94
95
96
97
98
99
100
101
102
103
#include "stdafx.h"
#include <stdio.h>
#include <stdlib.h>
 
typedef unsigned short int word; 
typedef unsigned int dword;
 
//замена цвета прямоугольника на синий при условии, что весь прямоугольник одного цвета
#pragma pack(push)
#pragma pack(1)
//рисунок 213*154=32802. Откуда 34342 ? 213%4=3 3*154(число строк)=462 462+32802=33264(размер картинки)
struct BitMapHeader
{
word bfType; // тип файла, для BMP - BM 
dword bfSize; // размер файла - dword (истинный размер 34342-1078+14)
word bfReserved1; // не используется 
word bfReserved2; // не используется 
dword bfOffbits; // смещение данных битового образа от заголовка в байтах (1078) 
 
// Далее идет структура BITMAPINFOHEADER 
 
dword biSize ; // число байт, занимаемых структурой BITMAPINFOHEADER 
dword biWidth; // ширина витового образа в пикселях
dword biHeight; // высота битового образа в пикселях
word biPlanes; // число битовых плоскостей устройства
word biBitCount; // число битов на пиксель 
dword biCompression; // тип сжатия 
dword biSizeImage; // размер картинки в байтах (без 1078 т.е.33264)
dword biXPelPerMeter; // горизонтальное разрешение устройства, пиксель/м 
dword biYPelPerMeter; // вертикальное разрешение устройства, пиксель/м 
dword biClrUsed; // число используемых цветов 
dword biClrImportant; // число "важных" цветов 
};
 
typedef unsigned char BYTE;
 
#pragma pack(pop)
 
struct tagRGBQUAD {
BYTE rgbBlue;
BYTE rgbGreen;
BYTE rgbRed;
BYTE rgbReserved;
} ;
 
BitMapHeader ReadHeader(FILE * f);
void ReadQuad(tagRGBQUAD* RGB,int biSize,FILE *f);
void WriteQuad(tagRGBQUAD* RGB,int biSize,FILE *f);
void colorChange(tagRGBQUAD* RGB,int biSize,FILE *f);
char letterM[3]={'A','C','D'};
int main(int argc, char* argv[])
{
BitMapHeader header;
tagRGBQUAD RGBQuad[256];
BYTE c;
FILE* fb; 
char filename[]="No_name.bmp";
int i;
if(!(fb=fopen(filename,"r+b"))){printf("file not open");return 1;}
 
// заголовок
header=ReadHeader(fb);
 
// некоторые важные размеры
printf("size of picture (biSizeImage)= %d\n",header.biSizeImage);
printf("bfsize=%d\n",header.bfSize);
printf("size of header+Quad (bfOffbits)= %d\n",header.bfOffbits);
printf("size of header (biSize+14)= %d\n",header.biSize+14);
 
// палитра
ReadQuad(RGBQuad,header.biSize+14,fb);
int nom=0;
 
for( i = 0; i < 255 ; i++ )
{
printf("clor number %3d B= %3d G= %3d R= %3d\n",i, RGBQuad[i].rgbBlue,RGBQuad[i].rgbGreen,RGBQuad[i].rgbRed);
if ((RGBQuad[i].rgbBlue==255)&&(RGBQuad[i].rgbGreen==0)&&(RGBQuad[i].rgbRed==255))
nom=i; 
}
printf("================================= \n");
printf("COLOR NUMBER= %d",nom);
printf("=================================\n");
//получить номер цвета прямоугольника
fseek(fb,header.bfOffbits,SEEK_SET);
c=nom;
for(i=0;i<header.biSizeImage;i++)
fwrite(&c,1,1,fb);
 
printf("color %x\n",(int)c);
int colorNumber=rand()%256;
char letter = rand()%('z'-'a')+'A';
char randLetter = letterM[rand()%3];
printf("color number %3d B= %3d G= %3d R= %3d\n",c, RGBQuad[c].rgbBlue,RGBQuad[c].rgbGreen,RGBQuad[c].rgbRed);
 
RGBQuad[c].rgbBlue=0;
RGBQuad[c].rgbGreen=0;
RGBQuad[c].rgbRed=0;
 printf("clor number %3d B= %3d G= %3d R= %3d\n",c, RGBQuad[c].rgbBlue,RGBQuad[c].rgbGreen,RGBQuad[c].rgbRed);
//запись палитры
 WriteQuad(RGBQuad,header.biSize+14,fb);
fclose(fb);
return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 19:19. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru