Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.82/11: Рейтинг темы: голосов - 11, средняя оценка - 4.82
0 / 0 / 0
Регистрация: 13.03.2015
Сообщений: 12

Поиск заданной буквы в двумерном массиве

13.03.2015, 15:37. Показов 2368. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите пожалуйста, не погу понять двухмерный массив. Задание:
Дано двухмерный символьный массив. Найти количество букв f.
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
13.03.2015, 15:37
Ответы с готовыми решениями:

Поиск числа в двумерном массиве (бинарный поиск)
Произвожу поиск элемента в массиве двумя способами: линейным(последовательным) поиском и бинарным(двоичным). Первый работает на ура. Второй...

Поиск минимума и максимума в двумерном массиве
#include "stdafx.h" #include <iostream> using namespace std; int main() { int n; cin >> n; int *a = new int; for...

Поиск элементов и замена в двумерном массиве
В массиве все элементы ,стоящие выше максимального элемента,заменить на максимальный элемент первого столбца! Есть часть кода где...

9
619 / 218 / 51
Регистрация: 22.11.2010
Сообщений: 1,781
Записей в блоге: 3
13.03.2015, 15:39
qwerkuhkduhfu
afawefawefawe
asdfawefagrgg
asdfasdfawefrt
посчитай сколько букв f в этом массиве.
Это и есть твоя задача.
0
 Аватар для MicM
840 / 498 / 325
Регистрация: 29.12.2009
Сообщений: 1,106
13.03.2015, 16:45
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
#include <iostream>
#include <algorithm>
#include <random>
#include <boost/numeric/ublas/matrix.hpp>
#include <boost/numeric/ublas/io.hpp>
 
namespace ublas = boost::numeric::ublas;
 
void fill_matrix (ublas::matrix<char> & A)
{
    std::random_device rng;
    std::uniform_int_distribution<> gen ('a', 'z');
    for (int i = 0; i < A.size1(); i++)
        for (int j = 0; j < A.size2(); j++)
            A(i,j) = gen(rng);
}
 
int main()
{
    ublas::matrix<char> A (4, 4);
    fill_matrix (A);
    std::cout <<A <<std::endl;
    int k = std::count (A.begin2(), A.begin2() + A.size2() * A.size1(), 'f');
    std::cout <<k <<std::endl;
}
1
0 / 0 / 0
Регистрация: 13.03.2015
Сообщений: 12
13.03.2015, 18:08  [ТС]
#include <iostream>
#include <algorithm>
#include <random>
#include <boost/numeric/ublas/matrix.hpp>
#include <boost/numeric/ublas/io.hpp>

namespace ublas = boost::numeric::ublas;

void fill_matrix (ublas::matrix<char> & A)
{
std::random_device rng;
std::uniform_int_distribution<> gen ('a', 'z');
for (int i = 0; i < A.size1(); i++)
for (int j = 0; j < A.size2(); j++)
A(i,j) = gen(rng);
}

int main()
{
ublas::matrix<char> A (4, 4);
fill_matrix (A);
std::cout <<A <<std::endl;
int k = std::count (A.begin2(), A.begin2() + A.size2() * A.size1(), 'f');
std::cout <<k <<std::endl;
}
А нельзя ли этот код как нибудь упростить, я только начинаю учить массивы и мне хотелось понять.
0
 Аватар для dvano
136 / 67 / 27
Регистрация: 18.06.2014
Сообщений: 216
13.03.2015, 18:31
Добавлю свои 5 копеек . Вариант, конечно, примитивный, и могут быть ошибки.
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
#include <iostream>
 
int main()
{
    char array[4][4] =
    {
        'd', '2', 'g', 'a',
        '5', 't', 'a', 'b',
        '9', 'f', 'z', 'j',
        '9', 'z', 'f', 'h'
    };
    
    unsigned temp = 0;
    
    for (unsigned i = 0; i < 4; i++)
    {
        for (unsigned j = 0; j < 4; j++)
        {
            if (*((char *)array + 4 * i + j) == 'f')
                temp++;
        }
    }
    
    std::cout << temp << '\n';
    
    return 0;
}
1
0 / 0 / 0
Регистрация: 13.03.2015
Сообщений: 12
13.03.2015, 18:56  [ТС]
#include <iostream>

int main()
{
char array[4][4] =
{
'd', '2', 'g', 'a',
'5', 't', 'a', 'b',
'9', 'f', 'z', 'j',
'9', 'z', 'f', 'h'
};

unsigned temp = 0;

for (unsigned i = 0; i < 4; i++)
{
for (unsigned j = 0; j < 4; j++)
{
if (*((char *)array + 4 * i + j) == 'f')
temp++;
}
}

std::cout << temp << '\n';

return 0;
}
Не пойму, она запускается и сразу же закрывается((
0
Модератор
Эксперт С++
 Аватар для zss
13773 / 10966 / 6491
Регистрация: 18.12.2011
Сообщений: 29,244
13.03.2015, 18:58
Лучший ответ Сообщение было отмечено Maxiqq как решение

Решение

Цитата Сообщение от Maxiqq Посмотреть сообщение
сразу же закрывается(
Распространенные ошибки

Вариант чуть проще
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <iostream>
 
int main()
{
    char array[4][16] ={"qwerkuhkduhfu","afawefawefawe","asdfawefagrgg","asdfasdfawefrt"};
    int count = 0;
    for (size_t  i = 0; i < 4; i++)
    {
        for (size_t j = 0; array[i][j]!=0; j++)
            if (array[i][j] == 'f')
                count++;
    }
   
    std::cout << count << '\n';
    system("pause");
    return 0;
}
1
0 / 0 / 0
Регистрация: 13.03.2015
Сообщений: 12
13.03.2015, 19:11  [ТС]
zss, можно ли ещё вопрос, мне нужно ввести массив и заменить все нулевые элементы последним элементом массива.
0
Модератор
Эксперт С++
 Аватар для zss
13773 / 10966 / 6491
Регистрация: 18.12.2011
Сообщений: 29,244
13.03.2015, 19:14
Этот вопрос не имеет отношение к текущей теме.
Воспользуйтесь поиском по форуму. Он много раз обсуждался.
Если не сможете найти создайте новую тему.
0
 Аватар для dvano
136 / 67 / 27
Регистрация: 18.06.2014
Сообщений: 216
13.03.2015, 19:22
zss, почему переменная count имеет тип int, а не size_t?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
13.03.2015, 19:22
Помогаю со студенческими работами здесь

Поиск минимального числа в двумерном массиве
Программка ищет минимальное число в массиве и выводит это число и его индексы проблема в том что индексы этого числа он выводит неправильно...

Поиск пиковых точек в двумерном массиве
Здравствуйте, подскажите пожалуйста алгоритм для поиска пиковых точек в двумерном массиве, то есть элементов матрицы, являющихся наибольшим...

Поиск трех максимальных элементов в двумерном массиве
не могу решить, казалось бы, простую задачку. помогите пожалуйста. В заданной целочисленной матрице a(n,n), которая инициализируется в...

Поиск максимального по модулю элемента в двумерном массиве
Почему для нахождения наибольшего по модулю элемента используется нулевая ячейка arr? int max = abs(arr); for (int i = 0; i...

поиск максимума в двумерном массиве, где ошибка
// lab2_1.cpp: определяет точку входа для консольного приложения. // #include &quot;stdafx.h&quot; #include &lt;conio.h&gt; #include...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru