Си++. Создать динамические массивы, используя указатели. Дано два массива x[n], y[m]. Сколько раз встречается второй элемент первого массива x[n] во втором y[m]. В main должно быть только объявление массива, выделение динамической памяти и вызов объявленных функций. Решить с использованием указателей, динамической памяти и функций. (мой код, который не работает) В чем ошибка?
#define CRT_SECURE_NO_WARINGS
#include
#include
#include
#include
int main()
{
setlocale(LC_ALL, "rus");
srand(time(NULL));
int* x, * y, n, m;
std::cout << "Введите размерность массивов:";
std::cin >> n, m;
Imass(x, n);
printf("\n");
IImass(y, m);
printf("\n");
Viimass(y, m);
printf("\n");
Z(x, y, n, m);
return 0;
}
void Imass(int x[], int nx) {
int i,n;
for (i = 0; i < n; i++)
x[i] = rand() % 5;
}
void IImass(int y[], int my) {
int i,m;
for (i = 0; i < m; i++)
y[i] = rand() % 5;
}
void Vimass(int x[],int nx) {
int i,n;
for (i = 0; i < n; i++)
std::cout << "Массив x[n]: " << x[i];
}
void Viimass(int y[],int my) {
int i,m;
for (i = 0; i < m; i++)
std::cout << "Массив y[m]: " << y[i];
}
void Z(int x[], int y[], int nx, int my) {
int i,n, k=0;
for (i = 0; i < n; i++) {
if (x[1] == y[i]) {
k++;
}
}
std::cout << "количество повторений второго элемента первого массива во втором массиве: " << k;
}
//Pascal ABC.NET v3.0 сборка 1111
//1
Var
a,p,s:real;
begin
readln(a);
p:=a*4;
s:=a*a;
writeln('P=',p);
writeln('S=',s);
end.
//2
Var
a,b:integer;
begin
read(a,b);
if a>b then writeln(b);
if a=b then writeln('=');
if a<b then writeln(a);
end.
{На этом и закончу всем, кто когда либо и чем либо поддерживал данный проект. Думаю, он ещё многим послужит в критический момент. И я говорю не только про "списать домашку". Счастливо оставаться, господин Alviko. Может, ещё увидимся.
Ваш, Глеб 'I3artle' Косырев}
Приведём все степени к основанию 2
2^3702-2^468+2^1620-108
-108 можно представить как -128 + 16 + 4
2^3702-2^468+2^1620-2^7 + 2^4 + 2^2
Теперь выстраиваем степени в порядке убывания:
2^3702+2^1620-2^468-2^7 + 2^4 + 2^2
В выражении два вычитания подряд, избавимся от этого, заменив -2^468 на -2^469 + 2^468
2^3702+2^1620 -2^469+2^468-2^7 + 2^4 + 2^2
2^3702 - 1 единица
2^4 - 1 единица
2^2 - 1 единица
Количество единиц в вычитаниях будет равно разнице степеней. Например 1000000-100=1111
2^1620 -2^469 - количеств единиц 1620-469 = 1151
2^468-2^7 - количество единиц 468-7 = 461
Общее количество единиц равно 3+1151+461 = 1615