作业训练------通过读取c.txt文件中的内容等号右值,并将右值的最大值、最小值、平均值打印到屏幕上。
这篇博客是学习传智播客c++教程的作业,通过在网上进行搜集来完成,但是网上有相似的代码,但是结果总是有点问题,所以本文写了这篇记录下。
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
//3.1去除字符串右边的空格
char *TrimStrR(char *SrcStr)
{
if (SrcStr == NULL)
{
printf("TrimStrR function is error!");
return NULL;
}
int i = ;
int iLen = strlen(SrcStr);
for(i = (iLen -);i>=;i--)
{
if(SrcStr[i] == ' ')
SrcStr[i] = ;
else
break;
}
return SrcStr;
}
//3.2去掉字符串左边的空格
char *TrimStrL(char *SrcStr)
{
if (SrcStr == NULL)
{
printf("TrimStrR function is error!");
return NULL;
}
if(SrcStr[] != ' ')
{
return SrcStr;
}
int i = ;
int iLen = strlen(SrcStr);
if(iLen == )
{
return SrcStr;
}
char *stemp = (char*)malloc(iLen+);
memset(stemp,,iLen+);
memcpy(stemp,SrcStr,iLen);
for(i = ;i<iLen;i++)
{
if(SrcStr[i] != ' ')
{
strcpy(stemp,SrcStr+i);
break;
}
}
strcpy(SrcStr,stemp);
free(stemp);
return SrcStr;
}
//3.3解析带等号的字符串并去掉字符串传尾部空格
void ParseValueStr(char *Des,char* SrcStr)
{
int iLen = strlen(SrcStr);
if(iLen == )
{
return ;
}
if((SrcStr[iLen -] == '\n')||(SrcStr[iLen -] == '\r'))
{
SrcStr[iLen -] = '\0';
}
if(iLen > )
{
if((SrcStr[iLen -] == '\n')||(SrcStr[iLen -] == '\r'))
{
SrcStr[iLen -] = '\0';
}
}
TrimStrR(SrcStr);
int i = ;
for(i= ;i<iLen;i++)
{
if((*SrcStr) == '=')
{
strcpy(Des,++SrcStr);
break;
}
++SrcStr;
}
TrimStrL(Des);
}
//3.4计算数组buf中的最大值,参数bufsize为参数buf的元素数量
int max(const int *buf,const int bufsize)
{
int tmp = buf[];
int i = ;
for(i = ;i<bufsize;i++)
{
if(tmp <= buf[i])
tmp = buf[i];
}
return tmp;
}
float avg(const int *buf,const int bufsize)
{
float sum = ;
int i = ;
for(i = ;i<bufsize;i++)
{
sum += buf[i];
}
return sum/bufsize;
}
int min(const int *buf,const int bufsize)
{
int tmp = buf[];
int i = ;
for(i = ;i<bufsize;i++)
{
if(buf[i] == )
continue;
if(tmp >= buf[i])
tmp = buf[i];
}
return tmp;
}
int main(int args, char*argc[])
{
if (args < )
{
printf("parameters is error!\n");
}
char buf[];
char value[];
int values[];
memset(values,,sizeof(values));
FILE* fp = fopen(argc[], "r");
int i = ;
int j = ;
while(!(feof(fp)))
{
memset(buf,,sizeof(buf));
memset(value,,sizeof(value));
fgets(buf,sizeof(buf),fp);
ParseValueStr(value,buf);
values[i] = atoi(value);
i++; }
for(j = ;j<i-;j++)
{
printf("%d\n",values[j]);
}
fclose(fp);
printf("最大值:%d\n",max(values,i));
printf("最小值:%d\n",min(values,i));
printf("平均值:%f\n",avg(values,i));
return ;
}
下面是运行后的结果:

作业训练------通过读取c.txt文件中的内容等号右值,并将右值的最大值、最小值、平均值打印到屏幕上。的更多相关文章
- Flex读取txt文件中的内容(三)
Flex读取txt文件中的内容 1.设计源码 LoadTxt.mxml: <?xml version="1.0" encoding="utf-8"?> ...
- Flex读取txt文件中的内容(二)
Flex读取txt文件中的内容 自动生成的文件 LoadTxt-app.xml: <?xml version="1.0" encoding="utf-8" ...
- Flex读取txt文件中的内容(一)
Flex读取txt文件中的内容 phone.txt: 13000003847 13000003848 13000003849 13000003850 13000003851 13000003852 1 ...
- Flex读取txt文件中的内容报错
Flex读取txt文件中的内容 1.具体错误如下 2.错误原因 读取文件不存在 var file:File = new File(File.applicationDirectory.nativePat ...
- 向txt文件中写入内容(覆盖重写与在末尾续写+FileOutputStream与FileWriter)(转发:https://blog.csdn.net/bestcxx/article/details/51381460)
!!!! 读取txt文件中的内容 import java.io.BufferedReader; import java.io.File; import java.io.FileReader; /** ...
- 代码实现:定义一个文件输入流,调用read(byte[] b)方法,将a.txt文件中的内容打印出来(byte数组大小限制为5)
package com.loaderman.test; import java.io.ByteArrayOutputStream; import java.io.FileInputStream; im ...
- 按行读取TXT文件中的内容
public Dictionary<int, string> GetDicFromLog() { try { StreamReader sr = new StreamReader(file ...
- js读取本地txt文件中的json数据
list.txt内容 [ {"optionKey":"1", "optionValue":"Canon in D"}, ...
- Java中读取txt文件中中文字符时,出现乱码的解决办法
这是我写的一个Java课程作业时,遇到的问题. 问题描述: 我要实现的就是将txt文件中的内容按一定格式读取出来后,存放在相应的数组. 我刚开始运行时发现,英文可以实现,但是中文字符就是各种乱码. 最 ...
随机推荐
- NOIP 2006 金明的预算方案(洛谷P1064,动态规划递推,01背包变形,滚动数组)
一.题目链接:P1064 金明的预算方案 二.思路 1.一共只有五种情况 @1.不买 @2.只买主件 @3.买主件和附件1(如果不存在附件也要运算,只是这时附件的数据是0,也就是算了对标准的结果也没影 ...
- 54.string field聚合以及fielddata原理初探
主要知识点: 直接对分词的term进行聚合后果 设置fielddata=true 直接用.keyword进行聚合 doc value 的性能问题 一.直接对分词的term进行聚合后果 ...
- Codeforces Round #395 C. Timofey and a tree
package codeforces; import java.util.*; public class CodeForces_764C_Timofey_and_a_tree { static fin ...
- Java Web学习总结(31)——全站HTTPS化SSL免费证书使用
1 背景 谷歌从 2017 年起,Chrome 浏览器将也会把采用 HTTP 协议的网站标记为「不安全」网站:苹果从 2017 年 iOS App 将强制使用 HTTPS:在国内热火朝天的小程序也要求 ...
- nyoj 5 Binary String Matching(string)
Binary String Matching 时间限制:3000 ms | 内存限制:65535 KB 难度:3 描述 Given two strings A and B, whose alp ...
- Wow! Such Sequence! (线段树) hdu4893
http://acm.hdu.edu.cn/showproblem.php?pid=4893 先贴上一份还没过的代码,不知道拿出错了 1 // by caonima ; ; ],col[MAX< ...
- 1874 Bellman-ford算法 队列优化过的 用于稀疏图,有负权的图
#include<stdio.h> #include<algorithm> #include<iostream> #include<queue> usi ...
- 总结for循环及for循环增强遍历数组,list,set和map
一.对于集合 (1)普通for循环 int[] arr = { 2, 1, 2 }; for(int i=0;i<arr.length;i++){ System.out.println(arr[ ...
- [poj1704]Georgia and Bob_博弈论
Georgia and Bob poj-1704 题目大意:题目链接 注释:略. 想法:我们从最后一个球开始,每两个凑成一对.如果有奇数个球,那就让第一个球和开始位置作为一对. 那么如果对手移动的是一 ...
- [Vue + TS] Watch for Changes in Vue Using the @Watch Decorator with TypeScript
Vue watchers allow to perform async updates as a side effect of a property change. This lesson shows ...