- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
首先,我不经常在这里发帖。如果这是不恰当的,我们深表歉意。我管理一些论坛,所以我理解为什么如果这是在错误的地方或回答了 1000 次(看上去成功率为 0。但可能没有看到正确的东西),您会感到沮丧。
我正在为我的一个学位模块 (C) 做一项作业,但我被困在一个项目上。
我正在尝试创建一个接受输入(test.txt)的线性回归公式。读取文本文件,将文本文件放入 2 个单独的数组(xArray、yArray)中。
然后,程序获取这两个数组并使用它们来完成程序的其余部分(执行各种计算以产生最终结果)。
现在,程序按预期运行。我确实有一些缩进问题(很抱歉,如果它让你的眼睛流血)。我使用了一个测试文件(有 6 行),它给出了正确的结果,所以如果它有效,我很高兴。
但是,只有当我使用与文件中的行匹配的数组大小时,它才有效(例如,如果文件中有 6 行,并且我将数组大小更改为 7)。它将产生 6 行精确值,第 7 行将为 0,0。这些值被视为 1,1。
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <ctype.h>
#include <string.h>
int xArray[6];
int yArray[6];
int nValue = sizeof(xArray)/sizeof(int);
int totalX = 0;
int totalY = 0;
int totalXY = 0;
int totalXSquared = 0;
char ch;
char name[10];
void main() {
// PROGRAM RUN
arraySetting();
sumofX();
sumofY();
sumofXY();
sumofXSquared();
formula();
}
int arraySetting() {
int x, y, n;
FILE *fptr;
fptr = fopen("test.txt", "r");
while (!feof(fptr)) {
for (int a = 0; a <= 6; a++) {
n = fscanf(fptr, "%d,%d", &xArray[a], &yArray[a]);
}
}
fclose(fptr);
printf("Read Data Printout\n");
// ARRAY PRINT
for (int a = 0; a < (sizeof(yArray)/sizeof(int)); a++) {
printf("x = %d y = %d\n", xArray[a], yArray[a]);
}
printf("\n");
printf("Printout read complete\n");
printf("Press ENTER key to Continue\n");
//here also if you press any other key will wait till pressing ENTER
scanf("%c",&ch); //works as getchar() but here extra variable is required.
}
int sumofX(){
for (int a = 0; a < (sizeof(xArray)/sizeof(int)); a++) {
totalX = totalX + xArray[a];
}
printf("The Sum of X is:%d\n",totalX);
printf("Press ENTER key to Continue\n");
//here also if you press any other key will wait till pressing ENTER
scanf("%c",&ch); //works as getchar() but here extra variable is required.
}
int sumofY(){
for (int a = 0; a < (sizeof(yArray)/sizeof(int)); a++) {
totalY = totalY + yArray[a];
}
printf("The Sum of Y is:%d\n",totalY);
printf("Press ENTER key to Continue\n");
//here also if you press any other key will wait till pressing ENTER
scanf("%c",&ch); //works as getchar() but here extra variable is required.
}
int sumofXY(){
for (int a = 0; a < nValue; a++) {
totalXY = totalXY + (xArray[a] * yArray[a]);
}
printf("The Sum of XY is:%d\n",totalXY);
printf("Press ENTER key to Continue\n");
//here also if you press any other key will wait till pressing ENTER
scanf("%c",&ch); //works as getchar() but here extra variable is required.
}
int sumofXSquared(){
for (int a = 0; a < (sizeof(xArray)/sizeof(int)); a++) {
totalXSquared = totalXSquared + (xArray[a]*xArray[a]);
}
printf("The Sum of Xsquared is:%d\n",totalXSquared);
printf("Press ENTER key to Continue\n");
//here also if you press any other key will wait till pressing ENTER
scanf("%c",&ch); //works as getchar() but here extra variable is required.
}
int formula() {
// INPUT THEM INTO FORMULA TO FIND A & B
double a;
double b;
double x;
double y;
double value;
// A CALCULATION
a = ((totalY * totalXSquared) - (totalX * totalXY));
a = a / ((nValue * totalXSquared) - (totalX * totalX));
// B CALCULATION
b = ((nValue * totalXY) - (totalX * totalY));
b = b / ((nValue * totalXSquared) - (totalX * totalX));
// USER INPUT
printf("Linear Regression formula\n\n");
printf("Y = %.2lf + %.2lfx\n\n",a, b);
printf("\nEnter a Value for X: ");
scanf("%lf", &x);
// USER INPUTTED VALUE INTO FORMULA TO CALCULATE 'Y'
y = a + (b * x);
printf("\nY = %.2lf + %.2lf x %.2lf\n", a, b, x);
printf("Y = %.2lf\n", y);
}
如果使用上述,读取文件的输出如下:
x = 43 y = 99
x = 21 y = 65
x = 25 y = 79
x = 42 y = 75
x = 57 y = 87
x = 59 y = 81
Printout read complete
Press ENTER key to Continue
但是,如果 xArray 或 yArray 更改为不同的值(例如 7)。可以看到如下:
Read Data Printout
x = 43 y = 99
x = 21 y = 65
x = 25 y = 79
x = 42 y = 75
x = 57 y = 87
x = 59 y = 81
x = 0 y = 0
Printout read complete
Press ENTER key to Continue
我理解我正在尝试做的事情的概念。该数组需要灵活地处理文件中的行。但是,我不确定如何执行此操作。
如有任何帮助,我们将不胜感激。
最佳答案
指针int *xArray
可用于根据需要分配内存。realloc
用于更改内存分配。如果指针设置为 NULL,则第一次调用 realloc
的行为与调用 malloc
的行为相同。对于大文件,最好按 block 分配内存并跟踪内存使用情况,而不是为每对数字分配内存。
#include <stdio.h>
#include <stdlib.h>
int *xArray = NULL;
int *yArray = NULL;
int nValue = 0;
int totalX = 0;
void arraySetting ( );
void sumofX ( );
int main ( void) {
arraySetting ( );
sumofX ( );
free ( xArray);
free ( yArray);
}
void arraySetting ( ) {
int x, y;
int *temp = NULL;
FILE *fptr = NULL;
if ( NULL == ( fptr = fopen("test.txt", "r"))) {
perror ( "test.txt");
exit ( EXIT_FAILURE);
}
while ( 2 == fscanf(fptr, "%d,%d", &x, &y)) {
if ( NULL == ( temp = realloc ( xArray, sizeof ( *xArray) * ( nValue + 1)))) {
fprintf ( stderr, "realloc problem xArray\n");
exit ( EXIT_FAILURE);
}
xArray = temp;
if ( NULL == ( temp = realloc ( yArray, sizeof ( *yArray) * ( nValue + 1)))) {
fprintf ( stderr, "realloc problem yArray\n");
exit ( EXIT_FAILURE);
}
yArray = temp;
xArray[nValue] = x;
yArray[nValue] = y;
nValue++;
}
fclose(fptr);
printf("Read Data Printout\n");
// ARRAY PRINT
for (int a = 0; a < nValue; a++) {
printf("x = %d y = %d\n", xArray[a], yArray[a]);
}
printf("\n");
printf("Printout read complete\n");
printf("Press ENTER key to Continue\n");
//here also if you press any other key will wait till pressing ENTER
char ch = 0;
scanf("%c",&ch); //works as getchar() but here extra variable is required.
}
void sumofX ( ) {
totalX = 0;
for (int a = 0; a < nValue; a++) {
totalX = totalX + xArray[a];
}
printf("The Sum of X is:%d\n",totalX);
printf("Press ENTER key to Continue\n");
//here also if you press any other key will wait till pressing ENTER
char ch = 0;
scanf("%c",&ch); //works as getchar() but here extra variable is required.
}
关于根据文件中的行创建数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58920144/
猫f1.txt阿曼维沙尔阿杰贾伊维杰拉胡尔曼尼什肖比特批评塔夫林现在输出应该符合上面给定的条件 最佳答案 您可以在文件读取循环中设置一个计数器并打印它, 计数=0 读取行时做 让我们数一数++ if
我正在尝试查找文件 1 和文件 2 中的共同行。如果公共(public)行存在,我想写入文件 2 中的行,否则打印文件 1 中的非公共(public)行。fin1 和 fin2 是这里的文件句柄。它读
我有这个 SQL 脚本: CREATE TABLE `table_1` ( `IDTable_1` int(11) NOT NULL, PRIMARY KEY (`IDTable_1`) );
我有 512 行要插入到数据库中。我想知道提交多个插入内容是否比提交一个大插入内容有任何优势。例如 1x 512 行插入 -- INSERT INTO mydb.mytable (id, phonen
如何从用户中选择user_id,SUB(row, row - 1),其中user_id=@userid我的表用户,id 为 1、3、4、10、11、23...(不是++) --id---------u
我曾尝试四处寻找解决此问题的最佳方法,但我找不到此类问题的任何先前示例。 我正在构建一个基于超本地化的互联网购物中心,该区域分为大约 3000 个区域。每个区域包含大约 300 个项目。它们是相似的项
preg_match('|phpVersion = (.*)\n|',$wampConfFileContents,$result); $phpVersion = str_replace('"','',
我正在尝试创建一个正则表达式,使用“搜索并替换全部”删除 200 个 txt 文件的第一行和最后 10 行 我尝试 (\s*^(\h*\S.*)){10} 删除包含的前 10 行空白,但效果不佳。 最
下面的代码从数据库中获取我需要的信息,但没有打印出所有信息。首先,我知道它从表中获取了所有正确的信息,因为我已经在 sql Developer 中尝试过查询。 public static void m
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我试图在两个表中插入记录,但出现异常。您能帮我解决这个问题吗? 首先我尝试了下面的代码。 await _testRepository.InsertAsync(test); await _xyzRepo
这个基本的 bootstrap CSS 显示 1 行 4 列: Text Text Text
如果我想从表中检索前 10 行,我将使用以下代码: SELECT * FROM Persons LIMIT 10 我想知道的是如何检索前 10 个结果之后的 10 个结果。 如果我在下面执行这段代码,
今天我开始使用 JexcelApi 并遇到了这个:当您尝试从特定位置获取元素时,不是像您通常期望的那样使用sheet.getCell(row,col),而是使用sheet.getCell(col,ro
我正在尝试在我的网站上开发一个用户个人资料系统,其中包含用户之前发布的 3 个帖子。我可以让它选择前 3 条记录,但它只会显示其中一条。我是不是因为凌晨 2 点就想编码而变得愚蠢? query($q)
我在互联网上寻找答案,但找不到任何答案。 (我可能问错了?)我有一个看起来像这样的表: 我一直在使用查询: SELECT title, date, SUM(money) FROM payments W
我有以下查询,我想从数据库中获取 100 个项目,但 host_id 多次出现在 urls 表中,我想每个 host_id 从该表中最多获取 10 个唯一行。 select * from urls j
我的数据库表中有超过 500 行具有特定日期。 查询特定日期的行。 select * from msgtable where cdate='18/07/2012' 这将返回 500 行。 如何逐行查询
我想使用 sed 从某一行开始打印 n 行、跳过 n 行、打印 n 行等,直到文本文件结束。例如在第 4 行声明,打印 5-9,跳过 10-14,打印 15-19 等 来自文件 1 2 3 4 5 6
我目前正在执行验证过程来检查用户的旧密码,但问题是我无法理解为什么我的查询返回零行,而预期它有 1 行。另一件事是,即使我不将密码文本转换为 md5,哈希密码仍然得到正确的答案,但我不知道为什么会发生
我是一名优秀的程序员,十分优秀!