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

Задача на с++ Черно-белая графика - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Задача на с ++ Вычисление суммы цифр строки http://www.cyberforum.ru/cpp-beginners/thread352258.html
нужно решить на С++ Дана строка, состоящая из символов, каждый из которых является знаком «+» или цифрой, начинающаяся и заканчивающаяся цифрой. Если в строке встречается сочетание «++», то выдать сообщение об ошибке, в противном случае вычислить получившуюся сумму. есть на Паскале const s = '2+6+8+9+1+5'; var i,res: integer; begin
C++ Форматы преобразования данных Пусть k - целое от 1 до 365. Присвоить целой переменной n значение 1,2,...6 или 7 в зависимости от того, на какой день недели (понедельник, вторник,..., суббота или воскресенье) приходится k- й день не високосного года, в котором 1 января - понедельник. http://www.cyberforum.ru/cpp-beginners/thread352257.html
C++ Задача на С++ Наибольшее отношение
Нужно решить задачу в С ++ Наибольшее отношение Условие задачи. Найдите наибольшее значение отношения трехзначного числа к сумме его цифр. Решение задачи на Паскале. Поскольку речь идет о трехзначных числах, то диапазон начинается с самого малого из них, т.е. 100, а заканчивается самым большим трехзначным числом 999. Задачу можно решить простым перебором всех вариантов, хотя сразу хочу...
C++ Проигрыватель на c++.
Я новичок в c++ раньше работал с delphi и php,сейчас учусь по Дейтл'у. Захотелось написать видео и аудио проигрыватель,хотелось бы поинтересоваться у опытных программистов какую литературу стоит читать по этой теме? Работаю на QT creator,помогите советом и по возможности полезной литературой. Проигрыватель нужен простенький что бы читал mp3 и avi,и не говорите что это слишком сложно для меня....
C++ Гаусс http://www.cyberforum.ru/cpp-beginners/thread352212.html
Ребят, помогите с кусочком программы реализации метода Гаусса. мне нужно приведение матрицы к треугольному виду. Заранее спасибо
C++ Олимпиада Задача 1. Поезда (20 баллов) Участок железной дороги проходит через станции, пронумерованные от 1 до N. Из расписания движения поездов известно, какой поезд на какой станции делает остановку. Требуется определить, за какое минимальное время можно добраться от станции с номером 1 до станции с номером Р, и количество сделанных пересадок. Максимальное время работы на одном тесте: 3 сек. ... подробнее

Показать сообщение отдельно
serik13
3 / 3 / 0
Регистрация: 04.01.2011
Сообщений: 71
16.09.2011, 18:33     Задача на с++ Черно-белая графика
Нужно решить на с++
заранее спасибоо!

Одна из базовых задач компьютерной графики – обработка черно-белых изображений. Изображения можно представить в виде прямоугольников шириной w и высотой h, разбитых на w×h единичных квадратов, каждый из которых имеет либо белый, либо черный цвет. Такие единичные квадраты называются пикселями. В памяти компьютера сами изображения хранятся в виде прямоугольных таблиц, содержащих нули и единицы.

Во многих областях очень часто возникает задача комбинации изображений. Одним из простейших методов комбинации, который используется при работе с черно-белыми изображениями, является попиксельное применение некоторой логической операции. Это означает, что значение пикселя результата получается применением этой логической операции к соответствующим пикселям аргументов. Логическая операция от двух аргументов обычно задается таблицей истинности, которая содержит значения операции для всех возможных комбинаций аргументов. Например, для операции «исключающее ИЛИ» эта таблица выглядит так.

Первый аргумент Второй аргумент Результат
0 0 0
0 1 1
1 0 1
1 1 0

Требуется написать программу, которая вычислит результат попиксельного применения заданной логической операции к двум черно-белым изображениям одинакового размера.
Формат входных данных

Первая строка входного файла содержит два целых числа w и h (1 ≤ w, h ≤ 100). Последующие h строк описывают первое изображение и каждая из этих строк содержит w символов, каждый из которых равен нулю или единице. Далее следует описание второго изображения в аналогичном формате. Последняя строка входного файла содержит описание логической операции в виде четырех чисел, каждое из которых – ноль или единица. Первое из них есть результат применения логической операции в случае, если оба аргумента – нули, второе – результат в случае, если первый аргумент – ноль, второй – единица, третье – результат в случае, если первый аргумент – единица, второй – ноль, а четвертый – в случае, если оба аргумента – единицы.
Формат выходных данных
В выходной файл необходимо вывести результат применения заданной логической операции к изображениям в том же формате, в котором изображения заданы во входном файле.

Пример входных и выходных данных
bw.in bw.out
5 3
01000
11110
01000
10110
00010
10110
0110 11110
11100
11110

Краткие методические рекомендации по решению задачи
Решение данной задачи в основном заключается в непосредственной аккуратной реализации операции, описанной в условии задачи. Для хранения заданной логической операции можно использовать массив целочисленного типа d[0..1,0..1], элемент которого d[i,j] хранит результат логической операции с первым аргументом i и вторым аргументом j. Таким образом, значение пикселя результата с координатами (x, y) будет равно d[a[x,y],b[x,y]], где a[1..h,1..w] и b[1..h,1..w] – целочисленные матрицы, хранящие исходные изображения.
При реализации решения особое внимание следует уделить этапу считывания исходных изображений и описания логической операции из входного файла, а также выводу результата работы программы в выходной файл.
В чем подвох?
Скажу по секрету, что у меня есть решения задач участников из Волгоградской области, по которым я могу сделать вывод, что многие из них не смогли считать данные из файла bw.in. Обратите внимание, что во входном файле, пробелы между символами есть только в первой строке. Во всех остальных строках, между символами нет пробелов.
Текст программы на Паскале одного из участников олимпиады:
Pascal
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
Var 
  P, Q : array [1..100,1..100] of boolean;
  O : array [False..True, False..True] of char;
  x, y, w, h : byte;
  c : char;
  f : text;
begin
  Assign(f,'bw.in');
  Reset(f);
  Readln(f,w,h);
  for y:=1 to h do
    begin
      for x:=1 to w do
        begin 
          read(f,c);
          if c='1' then 
            P[x,y]:=True 
          else 
            P[x,y]:=False;
        end;
       Readln (f);
    end;
  for y:=1 to h do
    begin
      for x:=1 to w do
        begin 
          read(f,c);
          if c='1' then 
            Q[x,y]:=True 
          else Q[x,y]:=False;
        end;
      Readln (f);
    end;
  Read(f, O[False,False], O[False,True], O[True,False], O[True,True]);
  Close(f);
 
  Assign(f,'bw.out');
  Rewrite(f);
  for y:=1 to h do
    begin 
      for x:=1 to w do 
        Write(f, O[P[x,y],Q[x,y]]);
      Writeln(f);
    end;
  Close(f);
end.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 15:51. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru