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

В неубывающей последовательности целых чисел найти количество пар чисел с заданной разностью "D" - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Задание на строки и символы http://www.cyberforum.ru/cpp-beginners/thread606566.html
Выполнить надо на С++ Дана строка символов. Напечатать слова, которые начинаются и заканчиваются одной и той же буквой
C++ Функция fread и матрицы Подскажите, как правильно исп. эту ф-ию для считывания информации из файла в матрицу. Есть маленькая программка, которая никак не хочет работать верно. В чём ошибка, не пойму. Вот код: #include<iostream> using namespace std; int main() { FILE *fb; int a; int i,j,n; if((fb=fopen("file.dat","rb"))==NULL) http://www.cyberforum.ru/cpp-beginners/thread606540.html
Динамическая матрица. вставка столбца C++
не получается вставка. задание таково, что после столбцов, не содержащих отрицательные элементы нужно вставить 2 столбец. вылетаю на строке t=stroka с ошибкой Access violation writing location 0xcdcdcdcd. void Vstavka_stolbca(int **&q,int *stroka,int n,int m,int Number) { int i,j=0; int **t=new int *; for(i=0;i<m;i++) t=new int ; if (Number==0) {
C++ Изменить расширение файла
имя файла заранее не известно
C++ Ограничение char http://www.cyberforum.ru/cpp-beginners/thread606479.html
var c:char; if c in then begin ... end; Как сделать в с++?
C++ Если в строке есть элемент, равный среднему арифметическому элементов этой строки, то вставьте после него строку, состоящую из этих элементов Я нахожу среднее ариф., элемент равный среднему арифметическому, но не пойму как вставить строку из этих элементов..то есть нужно вставлять все те же самые элементы? вот что я написала int Srednee_arif (int **A,int N, int M)// ищет среднее арифметическое каждой строки {int i,j; int sum = 0; for (int i=0; i<N; i++) sum=0; { for (int j=0; j<M; j++) { ... подробнее

Показать сообщение отдельно
dima koz
23 / 17 / 1
Регистрация: 05.06.2012
Сообщений: 72
Записей в блоге: 5
16.06.2012, 10:02     В неубывающей последовательности целых чисел найти количество пар чисел с заданной разностью "D"
stdafx.h:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
// stdafx.h: включаемый файл для стандартных системных включаемых файлов
// или включаемых файлов для конкретного проекта, которые часто используются, но
// не часто изменяются
//
 
#pragma once
 
#include "targetver.h"
 
#include <stdio.h>
#include <tchar.h>
 
#include <time.h>
#include <stdlib.h>
#include <iostream>
#include <conio.h>
 
#include <windows.h>
sequence.cpp:

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
114
115
116
117
// sequence.cpp: определяет точку входа для консольного приложения.
//
//Ввод из файла INPUT.TXT.
//В первой строке задаются через пробел два целых числа: количество членов последовательности N и разность D (2 <= N <= 106, 1 <= D <= 106).
//Во второй строке вводятся через пробел N натуральных чисел последовательности A1 <= A2 <= ...<= AN (Ai <= 109).
 
// Вывод в файл OUTPUT.TXT. Вывести число пар (Ai, Aj) таких, что Ai – A j = D.
// Ограничения. Время работы на одном тесте до 2 с. Объем используемой памяти до 1 Мгб.
// Пример
// Ввод
// 10 7
// 3 5 12 18 25 40 47 47 48 49
// Вывод
// 4
 
#include "stdafx.h"
 
using namespace std;
 
void recordingOriginalFile(); //заполнение/запись исходного файла
int getRandomInt(unsigned short int,unsigned short int); //получение рандомного числа типа Int
 
 
int _tmain(int argc, _TCHAR* argv[])
{
    //при  первом запуске программы, для программного создания файла для задания
    //при его наличии можно не использовать
    //написал, т.к. влом записывать файл вручную
    //recordingOriginalFile();
 
    //чтение input.txt
    //заполнение переменных заданными значениями
    int n,d;
 
    int FirstTime = GetTickCount();
    
    FILE *pFile1;
    fopen_s(&pFile1,"d:\\test\\input.txt", "r");
    fscanf_s(pFile1, "%d", &n);
    fscanf_s(pFile1, "%d", &d);
    int *arr = new int [n];
    for (int i = 0; i < n; i++)
    {
            fscanf_s(pFile1, "%d", &arr[i]);
    }
    fclose(pFile1);
 
    //поиск пар
    int count = 0; // счетчик пар
    for (int i = 0; i < n; i++)
    {
 
        for (int j = 0; j<n ; j++)
        {
            if (arr[i] - arr[j] == d) 
                count ++;
 
        }
    }
    count /=2 ;
    int SecondTime = GetTickCount();
    cout << "count ="<< count <<endl;
    cout << "runtime this programm = "<< SecondTime - FirstTime << " ms (1 s = 1000 ms)"<<endl;
    _getch();
    return 0;
}
 
//функция записывает входной файл с  заданными параметрами по условиям задачи
//
void recordingOriginalFile()
{
    const int n = 106; //количество членов последовательности N
    const int d = 11;   //разность D
 
    int original [n], hold;
    //заполняем массив размера n рандомно числами от 2 до n
 
    srand((unsigned int)time(NULL));
    bool sorted;
    for (int i=0;i<n;i++)
    original[i] = getRandomInt(2,n);
    // сортируем 
    for (int j = 1; j < n; j++)
        {
        sorted = true;
        for (int k = 0; k < n - 1; k++)
            if (original[k] > original[k + 1])
            {
                hold = original[k];
                original[k] = original[k + 1];
                original[k + 1] = hold;
                sorted = false;
            }
        if (sorted) 
            break;
        }   
 
    //записываем
    FILE *pFileOriginalRecording;
 
    fopen_s(&pFileOriginalRecording,"d:\\test\\input.txt", "w");
    fprintf(pFileOriginalRecording,"%d ",n);
    fprintf(pFileOriginalRecording,"%d ",d);
    fprintf(pFileOriginalRecording,"%c",char(10));
 
    for (int i = 0; i < n; i++)
    {
        fprintf(pFileOriginalRecording,"%d ",original[i]);
    }
    fclose(pFileOriginalRecording);
}
 
int getRandomInt(unsigned short int initialValue,unsigned short int finalValue)
{
    
    return  (initialValue + rand() % (finalValue-initialValue+1));
}
время выполнения несколько мс при N = 106, занимает в памяти не больше 700 кб

запись счетчика пар, думаю, сможешь самостоятельно сделать, по образцу в recordingOriginalFile()
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru