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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
zhivushko
0 / 0 / 0
Регистрация: 26.12.2013
Сообщений: 16
#1

Найти элемент массива, равный заданному числу Х и отпечатать его индекс - C++

30.12.2013, 00:02. Просмотров 384. Ответов 3
Метки нет (Все метки)

Задан массив чисел А[1:N,1:M],упорядоченный по возрастанию по строкам и столбцам, т.е. А[I, 1] < А[I, 2] < ... < А[I, M] (при всех I),
А[1, J] < A[2, J] < ... < А[N, J] (при всех J). Найти элемент массива, равный заданному числу Х и отпечатать его индексы (I,J). Напечатать слово
«НЕТ», если такого элемента не окажется. Х можно сравнить не более,
чем с M+N элементами массива.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
30.12.2013, 00:02     Найти элемент массива, равный заданному числу Х и отпечатать его индекс
Посмотрите здесь:

C++ Найти элемент массива, равный заданному числу Х или сообщить о его отсутствии
Найти элемент массива, равный заданному числу Х и отпечатать его индексы (I,J) C++
C++ Найти элемент массива наиболее близкий к заданному числу.
C++ Есть ли в данном массиве элемент, равный заданному числу? Если есть, то вывести номер одного из них.
Найти первый элемент массива, кратный заданному числу C++
C++ Каждый равный нулю элемент массива заменить полусуммой его соседних элементов
Найти первый отрицательный элемент массива и его индекс C++
Найти элемент массива который наименее близок к заданному числу C++
C++ Найти элемент массива, который наиболее близок к заданному числу R
C++ Найти наименьший элемент заданного массива и его индекс
Реализовать функцию, проверяющую, есть ли в массиве целых чисел элемент, равный заданному числу C++
Найти число такое, что произведение его цифр равняется заданному числу C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Jack Wade
62 / 35 / 6
Регистрация: 24.02.2013
Сообщений: 250
30.12.2013, 00:15     Найти элемент массива, равный заданному числу Х и отпечатать его индекс #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
#include <stdio.h>
 
int main(void)
{
int mas[10][10];
for (int i=0; i<10; i++)
for (int j=0; j<10; j++)
scanf("%d", &mas[i][j]);
//Сперва, сортируем массив по строчкам
for (int i=0; i<10; i++)
for (int j=0; j<9; j++)
{
if (mas[i,j]<mas[i][j+1])
{
int temp=mas[i][j];
mas[i][j]=mas[i][j+1];
mas[i][j+1]=temp;
}
}
//выводим на экран
for (int i=0; i<10; i++)
for (int j=0; j<10; j++)
fprint("[%d][%d] = %d\n", i,j,mas[i][j]);
_gettch();//Для того, чтобы успеть просмотреть результат до нажатия клавиши
//Теперь, сортируем по столбцам
for (int i=0; i<10; i++)
for (int j=0; j<9; j++)
{
if (mas[i][j]>mas[j+1][i])
{
int data=mas[j][i];
mas[j][i]=mas[j+1][i];
mas[j+1][i]=data;
}
}
//Отображаем результат на экране
for (int i=0; i<10; i++)
for (int j=0; j<10; j++)
printf("[%d][%d] = %d\n", i,j,mas[i][j]);
_gettch();
//Вводим число для поиска
int x=0;
scanf("%d", &x);
//Выполняем поиск таких чисел
bool yesno=false;//Т.е. пока таких чисел-нет
for (int i=0; i<10; i++)
for (int j=0; j<10; j++)
if (mas[i][j]==x) { printf("[%d][%d] = %d\n", i,j,mas[i][j]); yesno=true; /*Т.е. теперь "НЕТ" не будет отображено в конце*/ }
if (yesno==false) printf("НЕТ!\n");
_gettch();
}

Ну, как то так должно быть... Правда-код не проверял, но по логике-так...
rangerx
1923 / 1532 / 139
Регистрация: 31.05.2009
Сообщений: 2,896
30.12.2013, 00:31     Найти элемент массива, равный заданному числу Х и отпечатать его индекс #3
Цитата Сообщение от Jack Wade Посмотреть сообщение
for (int i=0; i<10; i++)
for (int j=0; j<10; j++)
if (mas[i][j]==x) { ... }
Цитата Сообщение от zhivushko Посмотреть сообщение
Х можно сравнить не более, чем с M+N элементами массива.
У вас число сравнений M*N.
Ev_Hyper
Заблокирован
30.12.2013, 00:38     Найти элемент массива, равный заданному числу Х и отпечатать его индекс #4
Возможно стоит взять элемент из середины и перебирая элементы 1-строка-1столбец получить ответ. Хотя я не уверен, что найдется за M+N раз. Так что надо немного подумать.
Yandex
Объявления
30.12.2013, 00:38     Найти элемент массива, равный заданному числу Х и отпечатать его индекс
Ответ Создать тему
Опции темы

Текущее время: 02:31. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru