RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1111243
Accepted
dbUser11
dbUser11
Asked:2020-04-16 21:25:51 +0000 UTC2020-04-16 21:25:51 +0000 UTC 2020-04-16 21:25:51 +0000 UTC

矢量内容未正确写入文件

  • 772

我有几个向量。他们的元素有一个处理。底线是我必须处理元素并将它们写入文件。所以我这样做,但我得到了一些垃圾。更准确地说,我得到了我应该得到的,但同时我得到了垃圾。

我举个例子。

我有两个文件。1.txt&2.txt

内容1.txt:

4.3 2.1 5.3 20.4 1.1 200.5

2.txt是我不断上传处理结果的文件。

示例 1. 在向量 X 的末尾添加另一个元素 - 14.3

预期的:4.3 2.1 5.3 20.4 1.1 200.5 14.3

挂号的:4.3 2.1 5.3 20.4 1.1 200.5 14.3 /20.4 /Y.

示例 2:将序列 Y 的元素分配给 X 值

预期的:4.3 /2.1 /5.3 /20.4 /1.1 /200.5 /14.3

挂号的:4.3 /2.1 /5.3 /20.4 /1.1 /200.5 /14.3 /Y.

示例 3:通过值查找元素的位置(正在寻找 200.5)

预期的:Элемент найден перед 14.3

挂号的:

Элемент найден перед 14.3
00.5 /14.3 /Y.

例 5。对序列的前五个元素进行排序

预期的:1.1 /2.1 /4.3 /5.3 /14.3 /200.5 /20.4

挂号的:1.1 /2.1 /4.3 /5.3 /14.3 /200.5 /20.4 /Y.

示例 6.从第一个序列中删除最后 3 个元素

预期的:4.3 2.1 5.3

挂号的:

4.3
 2.1
 5.3
  /14.3 /200.5 /20.4 /Y.

我怀疑我错误地组织了输出。但是如何正确组织呢?是否可以制作一个可以调用的正确工作函数,以免重复相同的代码 150 次?同样,我不知道该怎么做。

直接代码:

#include <iostream>
#include <fstream>
#include <algorithm>
#include <vector>
using namespace std;

void show_vector(vector<float>& vec);

int main()
{
    setlocale(0, "");
    cout << " 1) создал пустую последовательность Х\n";
    vector<float> X;

    cout << " 2) заполнил Х из файла 1.txt\n";
    ifstream fin;
    fin.open("1.txt");
    if (!fin) cout << "\nНе могу открыть файл 1.txt для чтения.\n";
    int counter = 0;
    while (!fin.eof()) {
        X.resize(counter + 1);
        fin >> X[counter];
        counter++;
    }
    fin.close();

    cout << " 3.1) добавил ещё один элемент в конец вектора\n";
    X.push_back(14.3);

    cout << " 3.2) записал измененную последовательность в файл 2.txt\n";
    fstream fout;
    fout.open("2.txt");
    if (!fout) cout << "\nНе могу открыть или создать файл 2.txt для записи.\n";
    for (size_t i = 0; i < X.size(); ++i) {
        fout << X[i] << " ";
    }
    fout.close();
    system("pause");

    cout << " 4) создать вторую пустую последовательность\n";
    vector<float> Y;

    cout << " 5.1) присвоил элементам второй последовательности значения первой\n";
    Y.assign(begin(X), end(X));

    cout << " 5.2) записать вторую последовательность в файл 2.txt\n";
    fout.open("2.txt");
    if (!fout) cout << "\nНе могу открыть или создать файл 2.txt для записи.\n";
    for (size_t i = 0; i < Y.size(); ++i) {
        fout << Y[i] << " /";
    }
    fout.close();
    system("pause");

    cout << " 6) найти во второй последовательности позицию элемента, значение которого вводится с клавиатуры результат записать в файл 2.\n";
    fout.open("2.txt");
    if (!fout) cout << "\nНе могу открыть или создать файл 2.txt для записи.\n";
    float x;
    cout << "Определите значение, позицию которого Вы хотите найти -->>  "; cin >> x;
    vector<float>::iterator i = find(Y.begin(), Y.end(), x);
    if (i == Y.end()) // если элемент не найден, то find вернет Y.end()
        fout << "Элемент не найден в последовательности Y.\n";
    else {
        fout << "Элемент найден";
        if (i == Y.begin())   cout << " - это первый элемент\n";
        else fout << " перед " << *++i << endl;
    }
    fout.close();
    system("pause");

    cout << " 7) упорядочить первые пять элементов второй последовательности и записать в 2.txt\n";
    partial_sort(Y.begin(), Y.begin()+5, Y.end());
    fout.open("2.txt");
    if (!fout) cout << "\nНе могу открыть или создать файл 2.txt для записи.\n";
    for (size_t i = 0; i < Y.size(); ++i) {
        fout << Y[i] << " /";
    }
    fout.close();
    system("pause");

    cout << " 8) с первой последовательности удалить последние 3 элемента. Записать последовательность в 2.txt\n";
    // sort(data.begin() + m - n), data.end()); - аналог. m - начало, n - конец
    for (int i = 0; i <= 3 && !X.empty(); ++i)
        X.pop_back();

    fout.open("2.txt");
    if (!fout) cout << "\nНе могу открыть или создать файл 2.txt для записи.\n";
    for (auto f : X) { fout << f << endl << " "; }
    fout.close();
    system("pause");

    cout << " 9) обменять содержимое первой и второй последовательности, результат вывести на экран с помощью итераторов\n";
    cout << "\nДо обмена\n" << "X -->> ";
    show_vector(X);
    cout << "\nY -->> ";
    show_vector(Y);

    X.swap(Y);
    cout << "\nПосле обмена\n" << "X -->> ";
    show_vector(X);
    cout << "\nY -->> ";
    show_vector(Y);

    cout << "\n\n 10) вычислить сумму и среднее арифметическое первой последовательности\n";
    float sum(0), avreage(0); counter = 0;
    for(size_t i = 0; i < X.size(); i++) {
        sum += X[i];
        counter++;
    }
    avreage = sum / counter;
    cout << endl << endl << "X -->> "; show_vector(X);
    cout << "\nСумма последовательности X -->> " << sum << ", среднее арифметическое последовательности X -->> " << avreage << endl;

    cout << "\n\n 11) ИЗ: поделить каждый положительный элемент вектора на минимальный элемент\n";
    cout << "\n\nX -->> ";
    show_vector(X);
    float MinElement = *min_element(X.begin(), X.end()); cout << "\nМинимальный элемент в X -->> " << MinElement << endl;
    for(size_t i = 0; i < X.size(); i++) {
        if (X[i] > 0) X[i] /= MinElement;
    }
    cout << "X -->> ";
    show_vector(X);

    cout << "\n\nY -->> ";
    show_vector(Y);
    MinElement = *min_element(Y.begin(), Y.end()); cout << "\nМинимальный элемент в Y -->> " << MinElement << endl;
    for (size_t i = 0; i < Y.size(); i++) {
        if (Y[i] > 0) Y[i] /= MinElement;
    }
    cout << "Y -->> ";
    show_vector(Y);

    return 0;
}

void show_vector(vector<float>& vec) {
    for(vector<float>::iterator it = vec.begin(); it != vec.end(); ++it)
        cout << *it << " ";
}

在所有情况下,我根据以下原则组织结论:

fsteram fout;
....
fout.open("2.txt");
    if (!fout) cout << "\nНе могу открыть или создать файл 2.txt для записи.\n";
    for (size_t i = 0; i < X.size(); ++i) {
        fout << X[i] << " ";
    }
    fout.close();
c++
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    KoVadim
    2020-04-16T21:57:34Z2020-04-16T21:57:34Z

    你遇到了一个不理解 eof 的典型问题。eof 不检查“文件是否结束”。它检查“上次读取时文件是否结束”。因此,读取了一个额外的数字

    而不是这个可怕的

    while (!fin.eof()) {
        X.resize(counter + 1);
        fin >> X[counter];
        counter++;
    }
    

    最好这样写

    float t;
    while (fin >> t) {
        X.push_back(t);
    }
    

    更漂亮更容易。

    • 2

相关问题

  • 编译器和模板处理

  • 指针。找到最小数量

  • C++,关于枚举类对象初始化的问题

  • 函数中的二维数组

  • 无法使用默认构造函数创建类对象

  • C++ 和循环依赖

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    如何从列表中打印最大元素(str 类型)的长度?

    • 2 个回答
  • Marko Smith

    如何在 PyQT5 中清除 QFrame 的内容

    • 1 个回答
  • Marko Smith

    如何将具有特定字符的字符串拆分为两个不同的列表?

    • 2 个回答
  • Marko Smith

    导航栏活动元素

    • 1 个回答
  • Marko Smith

    是否可以将文本放入数组中?[关闭]

    • 1 个回答
  • Marko Smith

    如何一次用多个分隔符拆分字符串?

    • 1 个回答
  • Marko Smith

    如何通过 ClassPath 创建 InputStream?

    • 2 个回答
  • Marko Smith

    在一个查询中连接多个表

    • 1 个回答
  • Marko Smith

    对列表列表中的所有值求和

    • 3 个回答
  • Marko Smith

    如何对齐 string.Format 中的列?

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5