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

Как сделать это с массивами?

11.05.2011, 20:43. Показов 1147. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Задан (и уже заполнен положительными числами) массив int A[50]. Необходимо написать фрагмент программы, который:
а) выведет на экран число, чаще всех остальных встречающееся в массиве А (для данного фрагмента программы построить блок-схему алгоритма);
б) рассчитает сумму чисел, являющихся квадратами каких-либо прочих элементов массива;
в) выведет числа из массива в виде таблицы, в которой номер строки будет соответствовать минимальному количеству десятков, которое превосходят соответствующие элементы массива. Например:
1) 8, 4, 6
2) 19, 17, 10, 12
3) 22, 28

Пункт а я сделал, б и в незнаю как... вот то что у меня есть...
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
#include <iostream>
#include <conio.h>
#include <time.h>
using namespace std;
 
const int n=50;
int main(){
int a[n];
int i,j,mx,mk,k;
srand(time(NULL));
for(i=0;i<n;i++)
 {
  a[i]=rand()%n+1;
  cout.width(3);
        cout<<a[i];
    }
cout<<endl;
mx=a[1]; mk=1; k=0;
 
for(i=1;i<= n;i++) 
 {
        for(j=1;j<=n;j++)
                if(a[i]==a[j]) k++;
 
if(((mk == k) && (mx < a[i])) || (mk < k)) 
 {
        mx=a[i]; mk=k; 
    }
k=0;
}
 
cout<<"chislo="<<mx<<" povtorov="<<mk<<endl; 
getch();
system ("PAuse");
return 0;
}
Добавлено через 5 часов 31 минуту
аууууууу
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
11.05.2011, 20:43
Ответы с готовыми решениями:

Поясните с массивами, как делать это задание
1. Дана последовательность натуральных чисел а1, a2, ..., а20. Определить, есть ли в последовательности хотя бы одна пара соседних нечетных...

нужно создать таблицу из 3 строк и 4 столбцов и заполнить её (любой информацией,это неважно) . Как это можно сделать ?
Здравствуйте.У меня возникла проблема. Помогите пожалуйста!Модуль в понедельник , про таблицы ничего не рассказывали , а преподаватель...

Манипуляции с массивами. Как сделать?
Товарищи, с наступающим всех! :) Очень нужна помощь. А то в новом году не допустят к сессии. :( :rtfm: Есть две небольших...

6
быдлокодер
 Аватар для kravam
1724 / 911 / 106
Регистрация: 04.06.2008
Сообщений: 5,702
11.05.2011, 21:40
Задание б
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
104
105
106
107
108
109
110
111
112
113
 #include <iostream>
 #include <conio.h>
 #include <time.h>
 #include <vector>
 using namespace std;
  
 const int n=50;
 
 //Это вот новые функцийки, которые я добавил
 //+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 int per_;
  bool IsOdd (int i) { return (i== per_); };
 void gen_random_uniq( int arr_size, int *parr, int range_min, int range_max ) {
  
 int i, j;
 int dup_flag;
 int rand_val, range_width= range_max-range_min+1;
  
  
  
 for ( i= 0; i<arr_size; i++ ) {
         for ( ; ; ) {
                 rand_val= range_min+rand()%range_width;
                 dup_flag= 0;
                 for ( j= 0; j<i; j++ ) {
                         if ( rand_val == parr[j] ) { dup_flag= 1; break; }
                 }
                 if ( !dup_flag ) { break; }
         }
         parr[i]= rand_val;
 }
         
 } /* gen_random_uniq() */
 //+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 
 
 int main(){
 int a[n];
 int i,j,mx,mk,k;
 srand(time(NULL));
 for(i=0;i<n;i++)
  {
   a[i]=rand()%n+1;
   cout.width(3);
                 cout<<a[i];
         }
 cout<<endl;
 mx=a[1]; mk=1; k=0;
  
 for(i=1;i<= n;i++) {
  for(j=1;j<=n;j++)                                if(a[i]==a[j]) k++;
  
 if(((mk == k) && (mx < a[i])) || (mk < k)) 
  {
                 mx=a[i]; mk=k; 
         }
 k=0;
 }
  
 cout<<"chislo="<<mx<<" povtorov="<<mk<<endl; 
 getch();
 system ("PAuse");
 
  //Делаем хитрые морды
  vector<int> vec (a, a + sizeof(a) / sizeof(int) );
 
  //Теперь удалим из вектора все элементы, равные "chislo"
  //Но сначала для нормальной работы IsOddсделаем так:
  per_= mx;
  //поехали удалять      
  vector<int>::iterator it= remove_if (vec.begin(), vec.end(), IsOdd); 
  vec.resize(it - vec.begin() );
 
  //ВЫведем вектор и его размер
  cout<<"vec.size= "<<  vec.size()<< endl;
  for (int i= 0; i< vec.size(); i++) {
   cout<<" "<<vec[i]<<" ";
  }
  cout<< endl;
 
  //Теперь найдём количество элементов, сумму квадратов которых будем расчитывать (случайно)
  int kol_vo= rand()%vec.size()+ 1;
  cout<<"kol_vo= "<<kol_vo<< endl;
 
  //OK, теперь скропаем массив из индексов этих елементов
  int* p= new int [kol_vo];
  
  //Теперь заполним этот массив случайными индексами;
  //Как? Вот здесь:
  //https://www.cyberforum.ru/cpp-beginners/thread44753.html
  //позаимствуем функцийку gen_random_uniq        
  gen_random_uniq(kol_vo, p, 0, vec.size()- 1);
  
  //ПОсмотрим, какие там индексы у нас получились:
  for (int i= 0; i< kol_vo; i++) {
   cout<<" "<<p[i]<<" ";
  }
  cout<< endl;
  
  
  //OK, в массиве p теперь индексы нужных нам элементов
  //Теперь просто:
  int sum= 0;
  for (int i= 0; i< kol_vo; i++) {
   sum+= vec[p[i]]* vec[p[i]];
   printf ("sum= %d\n", sum); 
  }          
    
  printf ("+++++++++++++++++++++++++\nsum= %d\n"); 
  
  getchar ();
 return 0;
 }
0
0 / 0 / 0
Регистрация: 06.05.2011
Сообщений: 34
12.05.2011, 11:02  [ТС]
а может кто-нибудь сможет подсказать как в делать
0
0 / 0 / 0
Регистрация: 06.05.2011
Сообщений: 34
14.05.2011, 07:35  [ТС]
буква б похоже не верно... как я понимаю по заданию она должна считать сумму элементов чисел являющихся квадратами прочих элементов в массиве... тоесть например есть число 9 и 3 и число 9 является квадрато 3 аналогично 25 и 5... нам и нужно подсчитать сумму 9 и 25... но как делать проверку на это?????
и подскажите кто-нибудь как букву в делать.... буду признателен за помощь....
0
быдлокодер
 Аватар для kravam
1724 / 911 / 106
Регистрация: 04.06.2008
Сообщений: 5,702
14.05.2011, 22:07
Задание б, тестируй
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
#include <iostream>
 #include <conio.h>
 #include <time.h>
 #include <vector>
 using namespace std;
  
 const int n=50;
 
 //Это вот новые функцийки, которые я добавил
 //+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  bool IsOdd_ (int a, int  b) {return (a==b*b);};
 //+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 
 
 int main(){
 int a[n];
 int i,j,mx,mk,k;
 srand(time(NULL));
 for(i=0;i<n;i++)
  {
   a[i]=rand()%n+1;
   cout.width(3);
                 cout<<a[i];
         }
 cout<<endl;
 mx=a[1]; mk=1; k=0;
  
 for(i=1;i<= n;i++) {
  for(j=1;j<=n;j++)                                if(a[i]==a[j]) k++;
  
 if(((mk == k) && (mx < a[i])) || (mk < k)) 
  {
                 mx=a[i]; mk=k; 
         }
 k=0;
 }
  
 cout<<"chislo="<<mx<<" povtorov="<<mk<<endl; 
 getch();
 system ("PAuse");
 
  //Делаем хитрые морды
  vector<int> vec (a, a + sizeof(a) / sizeof(int) );
 
  //Теперь просто
  int sum= 0;
  bool flag= false;
  for (int i= 0;i< vec.size(); i++) 
   for (int j= 0;j< vec.size(); j++)  
    if (IsOdd_(a[i],a[j])&&i!=j) {
     printf ("a[%d]= %d     a[%d]= %d\n", i, a[i], j, a[j]);
     sum+= a[i];
     flag= true;
     break;
    }
 
 cout<< "sum= "<< sum<< endl;  
 
 getchar ();
 return 0;
}
1
14.05.2011, 22:12

Не по теме:


название темы конечно извращенское :)
сорри за оффтоп, не сдержался

1
быдлокодер
 Аватар для kravam
1724 / 911 / 106
Регистрация: 04.06.2008
Сообщений: 5,702
14.05.2011, 23:14
А вот и задание в
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
#include <iostream>
 #include <conio.h>
 #include <time.h>
 #include <vector>
 using namespace std;
  
 const int n=50;
 
 //Это вот новые функцийки, которые я добавил
 //+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
  bool IsOdd_ (int a, int  b) {return (a==b*b);};
 //+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 
 
 int main(){
 int a[n];
 int i,j,mx,mk,k;
 srand(time(NULL));
 for(i=0;i<n;i++)
  {
   a[i]=rand()%n+1;
   cout.width(3);
                 cout<<a[i];
         }
 cout<<endl;
 mx=a[1]; mk=1; k=0;
  
 for(i=1;i<= n;i++) {
  for(j=1;j<=n;j++)                                if(a[i]==a[j]) k++;
  
 if(((mk == k) && (mx < a[i])) || (mk < k)) 
  {
                 mx=a[i]; mk=k; 
         }
 k=0;
 }
  
 cout<<"chislo="<<mx<<" povtorov="<<mk<<endl; 
 getch();
 system ("PAuse");
 
  //Делаем хитрые морды
  vector<int> vec (a, a + sizeof(a) / sizeof(int) );
 
  //Теперь просто
  int sum= 0;
  bool flag= false;
  for (int i= 0;i< vec.size(); i++) 
   for (int j= 0;j< vec.size(); j++)  
    if (IsOdd_(a[i],a[j])&&i!=j) {
     printf ("a[%d]= %d     a[%d]= %d\n", i, a[i], j, a[j]);
     sum+= a[i];
     flag= true;
     break;
    }
 cout<< "sum= "<< sum<< endl;  
 
 //++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 //Теперь так (это задание в):
 vector<vector<int> > vec_;
 vector<int> vec__;         
 k= 0;
 while (vec.size()) {
  for (int i= 0;i< vec.size(); i++) { 
   if (vec[i]/10==k) { 
    vec__.push_back(vec[i]);
    //проверить потом --
    vec.erase(vec.begin()+(i--));
   }
  }
  k++;
  vec_.push_back(vec__);
  vec__.resize (0);
 }
 
 //ВЫводим:
  printf ("\n"); 
  printf ("\n"); 
 for (int i= 0; i< vec_.size (); i++) {
  for (int j= 0; j< (vec_[i]).size(); j++)            
   printf ("%d  ", vec_[i][j]);            
  printf ("\n"); 
 }
 //++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 
 getchar ();
 return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
14.05.2011, 23:14
Помогаю со студенческими работами здесь

Как это сделать
У меня такой код #include &lt;iostream&gt; using namespace std; #include &lt;conio.h&gt; int main(){ char input = 'a'; double...

как это сделать
помогите, погибаю!!! тема: заставка(screan sever)? сменяющая картинки из списка особенности: поддержка эффектов смены, формирование...

Как это сделать?
Дан файл F, содержащий сведения об игрушках: название, стоимость, возрастные границы детей, для которых игрушка предназначена. Найти...

Как это сделать?
Ввести с клавиатуры целое число. Вывести «1», если последняя цифра этого числа 3,5 или 7, «2» - если 4,6 или 8, «3» - если 1 или 2, «0» - в...

Как это сделать?
Как написать прогу, которая бы указывала количество слов в предложении, вводимое пользователем?


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Ниже машинный перевод статьи The Thinkpad X220 Tablet is the best budget school laptop period . Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы,. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru