c语言练习

#include<stdio.h>
struct student{
char name[];
int No;
int sub[];
int sum;
};
int strcmp(char *s, char *t)
{
int i;
for(i = ; s[i] == t[i]; i ++)
if(s[i] == '\0')
return ;
return s[i] - t[i];
}
int main()
{
struct student stu[];
struct student sort_byname[], sort_byNo[], sort_bysum[];
int i, j, a, b, c;
int last_three;
// open file
FILE *fp;
fp = fopen("info.dat" , "r");
// operate file
i = a = b = c = ;
while(!feof(fp)){
fscanf(fp, "%s %d %d %d %d %d", &stu[i].name, &stu[i].No, &stu[i].sub[], &stu[i].sub[], &stu[i].sub[], &stu[i].sub[]);
// printf("%s %d %d %d %d %d\n", stu[i].name, stu[i].No, stu[i].sub[0], stu[i].sub[1], stu[i].sub[2], stu[i].sub[3]);
last_three = stu[i].No % ;
// printf("%d\n", last_three);
if(last_three% == )
sort_byname[a++] = stu[i];
else if(last_three% == )
sort_byNo[b++] = stu[i];
else if(last_three% == )
sort_bysum[c++] = stu[i];
i++;
}
for(int k = ; k < i; k++)
for(int l = ; l < ; l++)
stu[k].sum += stu[k].sub[l];
//printf("%s\n", sort_byname[1].name);
// printf("x = %d\n", strcmp("abcd" , "zabcd"));
// close file
fclose(fp);
struct student temp;
for(i = ; i < a; i++)
for(j = ; j < a-i-; j++)
if(strcmp(sort_byname[j].name , sort_byname[j+].name) > ){
temp = sort_byname[j];
sort_byname[j] = sort_byname[j+];
sort_byname[j+] = temp;
}
for(i = ; i < b; i++)
for(j = ; j < b-i-; j++)
if(sort_byNo[j].No > sort_byNo[j].No){
temp = sort_byname[j];
sort_byname[j] = sort_byname[j+];
sort_byname[j+] = temp;
}
for(i = ; i < c; i++)
for(j = ; j < c-i-; j++)
if(sort_bysum[j].sum > sort_bysum[j].sum){
temp = sort_byname[j];
sort_byname[j] = sort_byname[j+];
sort_byname[j+] = temp;
}
// open file
FILE *fp2;
fp2 = fopen("infosort.dat" , "w");
// operate file
fprintf(fp2, "sort_byname:\n");
for(i = ; i < a; i++)
fprintf(fp2, "%s %d %d %d %d %d\n", sort_byname[i].name, sort_byname[i].No, sort_byname[i].sub[], sort_byname[i].sub[], sort_byname[i].sub[], sort_byname[i].sub[]);
fprintf(fp2, "sort_byNo:\n");
for(i = ; i < b; i++)
fprintf(fp2, "%s %d %d %d %d %d\n", sort_byNo[i].name, sort_byNo[i].No, sort_byNo[i].sub[], sort_byNo[i].sub[], sort_byNo[i].sub[], sort_byNo[i].sub[]);
fprintf(fp2, "sort_bysum:\n");
for(i = ; i < c; i++)
fprintf(fp2, "%s %d %d %d %d %d\n", sort_bysum[i].name, sort_bysum[i].No, sort_bysum[i].sub[], sort_bysum[i].sub[], sort_bysum[i].sub[], sort_bysum[i].sub[]);
// close file
fclose(fp2);
return ;
}
注释是在写的中途的测试
以下是由于没写测试写崩的代码(没有正确结果):
#include<stdio.h>
#define MAX 100 struct student{
char name[];
int num;
int score[];
int sum;
}; int main()
{
struct student stu[MAX];
int i, j, k;
struct student sort_byname[MAX], sort_bynum[MAX], sort_bysum[MAX];
int a, b, c; // 统计各类学生的数目 // 1-从文件info.dat读入数据并分类
FILE *fp;
fp = fopen("info.dat" , "r"); i = a = b = c = ;
while(!feof){
fscanf(fp , "%s", &stu[i].name);
fscanf(fp , "%d", &stu[i].num);
for(k = ; k < ; k++){
fscanf(fp, "%d", &stu[i].score[k]);
stu[i].sum += stu[i].score[k]; // 统计总分
}
// 分类
if(stu[i].num% == )
sort_byname[a++] = stu[i];
if(stu[i].num% == )
sort_bynum[b++] = stu[i];
if(stu[i].num% == )
sort_bysum[c++] = stu[i];
i++;
} fclose(fp); // 2-对数据进行排序
int strcmp(char *s, char *t);
void swap(struct student *s, struct student *t); for(i = ; i < a; i ++)
for(j = ; j < a-i-; j ++)
if(strcmp(sort_byname[j].name , sort_byname[j+].name) > )
swap(&sort_byname[j] , &sort_byname[j+]); for(i = ; i < b; i ++)
for(j = ; j < b-i-; j ++)
if(sort_bynum[j].num > sort_bynum[j+].num)
swap(&sort_bynum[j] , &sort_bynum[j+]); for(i = ; i < c; i ++)
for(j = ; j < c-i-; j ++)
if(sort_bynum[j].sum > sort_bynum[j+].sum)
swap(&sort_bysum[j] , &sort_bysum[j+]); // 3-将数据写入 infosort.dat 以下可以用函数实现。。。。。。
fp = fopen("infosort.dat" , "w"); fprintf(fp, "sort_byname:\n");
for(i = ; i < a; i ++){
fprintf(fp , "%s ", sort_byname[i].name);
fprintf(fp , "%d ", sort_byname[i].num);
for(k = ; k < ; k++)
fprintf(fp, "%d ", sort_byname[i].score[k]);
}
fprintf(fp, "sort_bynum:\n");
for(i = ; i < b; i ++){
fprintf(fp , "%s ", sort_bynum[i].name);
fprintf(fp , "%d ", sort_bynum[i].num);
for(k = ; k < ; k++)
fprintf(fp, "%d ", sort_bynum[i].score[k]);
}
fprintf(fp, "sort_bysum:\n");
for(i = ; i < c; i ++){
fprintf(fp , "%s ", sort_bysum[i].name);
fprintf(fp , "%d ", sort_bysum[i].num);
for(k = ; k < ; k++)
fprintf(fp, "%d ", sort_bysum[i].score[k]);
} fclose(fp);
return ;
} int strcmp(char *s, char *t)
{
int i; for(i = ; s[i] == t[i]; i ++)
if(s[i] == '\0')
return ;
return s[i] - t[i];
} void swap(struct student *s, struct student *t)
{
struct student temp; temp = *s;
*s = *t;
*t = temp;
}
测试文件:
wang 67.5 78.9 88.0 99.2
zhang 89.7 45.6 78.8 85.7
tang 56.6 77.7 89.9 85.7
li 56.6 45.6 56.6 85.7
ren 99.9 77.7 89.9 85.7
fa 44.4 55.5 56.6 85.7
compu 56.6 77.7 89.9 85.7
c语言练习的更多相关文章
- C语言 · 高精度加法
问题描述 输入两个整数a和b,输出这两个整数的和.a和b都不超过100位. 算法描述 由于a和b都比较大,所以不能直接使用语言中的标准数据类型来存储.对于这种问题,一般使用数组来处理. 定义一个数组A ...
- Windows server 2012 添加中文语言包(英文转为中文)(离线)
Windows server 2012 添加中文语言包(英文转为中文)(离线) 相关资料: 公司环境:亚马孙aws虚拟机 英文版Windows2012 中文SQL Server2012安装包,需要安装 ...
- iOS开发系列--Swift语言
概述 Swift是苹果2014年推出的全新的编程语言,它继承了C语言.ObjC的特性,且克服了C语言的兼容性问题.Swift发展过程中不仅保留了ObjC很多语法特性,它也借鉴了多种现代化语言的特点,在 ...
- C语言 · Anagrams问题
问题描述 Anagrams指的是具有如下特性的两个单词:在这两个单词当中,每一个英文字母(不区分大小写)所出现的次数都是相同的.例如,"Unclear"和"Nuclear ...
- C语言 · 字符转对比
问题描述 给定两个仅由大写字母或小写字母组成的字符串(长度介于1到10之间),它们之间的关系是以下4中情况之一: 1:两个字符串长度不等.比如 Beijing 和 Hebei 2:两个字符串不仅长度相 ...
- JAVA语言中的修饰符
JAVA语言中的修饰符 -----------------------------------------------01--------------------------------------- ...
- Atitit 项目语言的选择 java c#.net php??
Atitit 项目语言的选择 java c#.net php?? 1.1. 编程语言与技术,应该使用开放式的目前流行的语言趋势1 1.2. 从个人职业生涯考虑,java优先1 1.3. 从项目实际来 ...
- 【开源】简单4步搞定QQ登录,无需什么代码功底【无语言界限】
说17号发超简单的教程就17号,qq核审通过后就封装了这个,现在放出来~~ 这个是我封装的一个开源项目:https://github.com/dunitian/LoTQQLogin ————————— ...
- InstallShield 脚本语言学习笔记
InstallShield脚本语言是类似C语言,利用InstallShield的向导或模板都可以生成基本的脚本程序框架,可以在此基础上按自己的意愿进行修改和添加. 一.基本语法规则 ...
- 用C语言封装OC对象(耐心阅读,非常重要)
用C语言封装OC对象(耐心阅读,非常重要) 本文的主要内容来自这里 前言 做iOS开发的朋友,对OC肯定非常了解,那么大家有没有想过OC中NSInteger,NSObject,NSString这些对象 ...
随机推荐
- fopen,fread和fwrite
在最近的编程练习和写东西的过程中,常常用到了fopen和fread两个函数来读取本地文件.之前使用这两个函数时,一直没有出现过什么问题.也是因为没有出现问题,对这两个函数的用法的一些细节没有很了解,所 ...
- 不同数据库中同一张表的SQL循环修改语句
select sample_value,Sample_GUID,row_number() over(order by sample_value )as rownumber into #AATemp ...
- mysql时间属性之时间戳和datetime之间的转换
一.datetime转换为时间戳 方案一:强制转换字段类型 use`nec`; ; ) NOT NULL COMMENT '注册时间' , ) NULL DEFAULT NULL COMMEN ...
- 2-MySQL数据库编码uft-8
mysql> show variables like 'character%'; mysql> show variables like 'collation%'; mysql> st ...
- WPF 札记
今天在工程中发现了一个非常消耗CPU资源的过程---一个创建Popup并根据绑定的Collection填充ListBox的过程. 通过VS的性能诊断,最终确定的耗时过程锁定在了Popup.isOpen ...
- Djunit工作记录
1.下载djunit 解压后放置到eclipse的plugins目录下即可 2.测试程序必须继承DjunitTestCase 3.测试程序完run as DJunitTest 运行 4.在djunit ...
- lisp等
- logstash实战
官网上的文档没有更新,估计快商业化了,elasticsearch和kibana 都内嵌了不用再下载,可以参看1.3.3的,除了打个包外没啥区别 http://logstash.net/docs/1.3 ...
- GridView的高度自适应
接着上面一篇文章. 当GridView不知道parent高度的时候,也就是MeasureSpec是UNSPECIFIED,这个时候,GridView高度为第一个child的高度,并显示滚动条. mIt ...
- viewport设置
<meta name="viewport" content="width=device-width, initial-scale=1.0,user-scalable ...