资源描述
C语言课程设计
院系:
姓名:
学号:
班号:
指导教师:
日期:2007年9月
第一部分
1.设计题目:
一种简单份的英文词典排版系统
2实践目的
通过进行计算机实践,更加系统地理解和掌握C语言的基本概
念、语言特点和编程技巧。利用系统提供的标准函数和自定义函数进
行程序设计,培养利用C语言设计综合程序的能力。
2.要求:
(1)能输入和显示打入的词。
(2)能分辨出单词。
(3)对重复的单词和已输入的单词能自动排除。
(4)能按A----Z排序排版。
(5)能将运行结果以文本形式存储。
(6)具有添加新单词并重新排版的能力。
3.分析:
运行结果以文本形式存储,因而要提供文件份额输入输出操作;通过查找操作检查重复单词;提供排序操作实现按A---Z的顺序排版;
提供插入操作添加新单词并重新排版。另外通过键盘式菜单实现功能选择。
数据结构采用指针数组或二维数组。以回车键或者空格键作为单词输入结束标志对重复的单词自动排除排除可选第一章的查找方法,数据结构可采用指针和数组。
第二部分
1.总体设计
整个系统被设计为单词录入模块,文件存储模块和单词浏览四个模块。
其中单词录入模块要完成输入单词,检查是否重复,排序操作。文件存储模块把存放单词的词组中的数据写入文件。
单词浏览模块完成英文词典的输出,即文件的输出操作。
这四个模块是整体的设计思路,设计核心,整个程序的设计都将围绕这四个模块进行,各个模块都相互衔接,所以需要在设计好各个部分地同时,还要把握好各个部分的连接。
以下这个是简单的设计模块:
英文词典排版系统
单词录入
文件存储
单词浏览
2详细设计
按照上面的整体思路,分别设计各个模块。
单词录入模块要完成输入单词,检查是否重复,排序操作。是设计程序的核心部分,对于检查是否重复,以及排序两个主要方面,我在设计中采用了两个结构体。
文件存储模块把存放单词的词组中的数据写入文件,这个模块还需具有天将新单词的功能。
单词浏览模块完成英文词典的输出,即文件的输出操作。将文件储存模块的内容输出。
[流程图]
输入单词
检查是否重复
删除
No yes
no排序操作
文件存储 单词输出
主函数一般设计的简洁,只提供输入,输出,功能处理和输出部分的函数使用。其中各功能模块选择菜单方式。
以下是主要的设计程序:
[程序]
#define N 1000
char dic[N][20];
void main()
{
Cheak();
sort();
Work();
}
} 该程序以菜单的形式简要反映了主要的设计思路。包含了几个主要模块的核心部分。
3各功能模块设计
1. 单词录入
单词可是字符型,输入时可采用字符型数组;
这是一个重要的模块,包含设计的几个重要部分, 这个模块包含着几个功能,输入单词,检查单词,删除重复的单词,并且对单词进行排序,比较复杂。
流程图如下:
输入单词
检查单词,并排序
由于需要检查是否有多于的单词,而且还要对单词进行排序,所以这个模块需要采用结构体。
(1)
对单词进行排序
输入单词
判断条件
排序
以下的是程序:
void Write( int r )
{
int i;
p = fopen( "Data.txt", "w" );
for( i = 0; i < r; i++ )
{
fprintf( p, "%s\n", dic[i] );
}
fclose(p);
nt sort( )
{
int i, j, flag = 1, r;
char s[20];
r = Read();
for( i = 1; i < r && flag == 1; i++ )
{
flag = 0;
for( j = 0; j < r-i; j++ )
{
if( strcmp( dic[j], dic[j+1] ) > 0 )
{
flag = 1;
strcpy( s, dic[j] );
strcpy( dic[j], dic[j+1] );
strcpy( dic[j+1], s );
}
}
}
Write( r );
return 0;
}
} 这个结构体采用了strcmp函数,对单词进行比较,从而完成排序。
(2)
检查删除重复的单词
这个模块的流程图如下:
单词
条件
删除重复的单词
以下是这个结构体的设计程序:
clear();
for( i = 0; i < r; i++ )
{
if( strcmp( d, dic[i] ) == 0 )
{
printf( "the word %s has already existed\n",d );
flag = 1;
break;
}
}
if( flag == 0 )
{
printf( "the word %s is successfully added\n", d );
strcpy( dic[r], d );
r++;
}
printf( "\n\ncontinue adding,please input a word;back to main menu,input 0 :\n" );
while( scanf( "%s", f ) && ! ( f[0] == '0' && f[1] == 0 ) )
{
flag = 0;
for( i = 0; i < r; i++ )
{
if( strcmp( f, dic[i] ) == 0 )
{
clear();
printf( "the word %s has already existed\n",d );
flag = 1;
break;
}
}
if( flag == 0 )
{
clear();
printf( "the word %s is successfully added\n", f );
strcpy( dic[r], f );
r++;
}
printf( "\n\ncontinue adding,please input a word;back to main menu,input 0 :\n" );
}
Write( r );
sort();
clear();
return;
}
这个模块同样运用了strcmp函数,通过比较删除重复的单词。
2文件储存模块
这个模块的流程图:
检查排序好的单词
储存单词
将上面整理好的单词以文件的形式储存,而且这个模块能具有被补充新单词的功能。
其设计程序如下:
int Read()
{
int r = 0;
p = fopen( "Data.txt", "r" );
while( fscanf( p, "%s", dic[r] ) != EOF )
{
r++;
}
fclose(p);
Write(r);
return r;
}3.单词浏览
这个模块的流程图,这个模块相对较简单:
储存的文件
输出单词
这个模块的任务就是将出存在文件里的单词输出来,虽然比较简单,是显示最后结果的一步。需将前面的那个个模块的内容输出即可。
以上的几个部分紧密相联,而且每个部分都很重要,相互衔接,
因此每个设计模块都不能忽视。只有每个部分都不出现漏洞,才能完成最后目的。
他的程序是:
oid Find( char *s )
{
char t[20];
int flag = 0;
char f[20];
int r = 0, c, i;
int temp;
p = fopen( "Data.txt", "r" );
clear();
while( fscanf( p, "%s", t ) != EOF )
{
strcpy( dic[r], t );
r++;
temp = strcmp( s, t );
if( temp == 0 )
{
c = r;
flag = 1;
}
}
Write( r );
if( flag )
{
printf( "%s's sequence number is %d!\n", s, c );
}
else
{
printf( "can not find %s!\n", s );
}
printf( "\n\ncontinue lookuping,please input a word;back to main menu,input 0 :\n" );
while( scanf( "%s", f ) && ! ( f[0] == '0' && f[1] == 0 ) )
{
flag = 0;
for( i = 0; i < r; i++ )
{
if( strcmp( f, dic[i] ) == 0 )
{
flag = 1;
c = i+1;
break;
}
}
if( flag )
{
clear();
printf( "%s's sequence number is %d!\n", f, c );
}
else
{
clear();
printf( "can not find %s!\n", f );
}
printf( "\n\ncontinue lookuping,please input a word;back to main menu,input 0 :\n" );
}
clear();
return;
}
第三部分
设计感想:
在老师的带领下进行了C语言程序实践学习。在短短一周的实习期间使我获取了不少新知识也巩固了许多老知识。
C语言是需要有一定基础、而且动手能力强的学科。上机实验是学习程序设计语言必不可少的实践环节,特别是C语言灵活、简洁,更需要通过编程的实践来真正掌握它。对于程序设计语言的学习目的,可以概括为学习语法规定、巩固贯穿系统知识、掌握程序设计方法、提高程序设计能力。
通过多次上机练习,对于语法知识有了感性的认识,加深对它的理解,在理解的基础上就会自然而然地掌握C语言的语法规定。对于一些内容自己认为在课堂上听懂了,但上机实践中会发现原来理解的偏差,更加巩固了学过的知识。
这次上机实习让我学到了很多有用的东西,巩固了之前的学习,让我学到了在教室和做题中学不到的一些知识,通过这个程序的学习,使我进一步理解和运用结构化程序设计的思想和方法。初步掌握开发一个小型实用系统的基本方法,学会调试一个比较长程序的基本方法,学会利用流程图表示算法,进一步掌握和提高利用C语言进行程序设计的能力。
我认为,这次实习对于我是非常有意义的,对我个人的影响比较大,对我的动手能力有了很大的提高。
第四部分
上机操作:
编译、连接和运行
下面是运行后各个模块的界面图:
1 主菜单函数:
2 单词输入功能
3.单词查找
4。查看所有单词
附录:
源程序:
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#define N 1000
char dic[N][20];
FILE *p;
void clear()
{
system("cls");
}
void Write( int r )
{
int i;
p = fopen( "Data.txt", "w" );
for( i = 0; i < r; i++ )
{
fprintf( p, "%s\n", dic[i] );
}
fclose(p);
}
int Read()
{
int r = 0;
p = fopen( "Data.txt", "r" );
while( fscanf( p, "%s", dic[r] ) != EOF )
{
r++;
}
fclose(p);
Write(r);
return r;
}
void Print()
{
printf( "\n\n" );
printf( " ********************************************************\n" );
printf( " * way = 1 : append words *\n" );
printf( " * way = 2 : lookup words *\n" );
printf( " * way = 3 : end work *\n" );
printf( " * way = 4 : cheak *\n" );
printf( " ********************************************************\n" );
printf( "please choose a way = " );
}
int sort( )
{
int i, j, flag = 1, r;
char s[20];
r = Read();
for( i = 1; i < r && flag == 1; i++ )
{
flag = 0;
for( j = 0; j < r-i; j++ )
{
if( strcmp( dic[j], dic[j+1] ) > 0 )
{
flag = 1;
strcpy( s, dic[j] );
strcpy( dic[j], dic[j+1] );
strcpy( dic[j+1], s );
}
}
}
Write( r );
return 0;
}
void Cheak()
{
int r = 0;
clear();
p = fopen( "Data.txt", "r" );
while( fscanf( p, "%s", dic[r] ) != EOF )
{
printf( "%s ", dic[r] );
r++;
}
fclose(p);
Write(r);
if( r == 0 )printf( "there is no word in Data.txt\n" );
else
{
printf( "\n\nthere are %d words in Data.txt!\n", r );
}
}
void Insert( char *d )
{
int i;
char f[20];
int r = Read();
int flag = 0;
clear();
for( i = 0; i < r; i++ )
{
if( strcmp( d, dic[i] ) == 0 )
{
printf( "the word %s has already existed\n",d );
flag = 1;
break;
}
}
if( flag == 0 )
{
printf( "the word %s is successfully added\n", d );
strcpy( dic[r], d );
r++;
}
printf( "\n\ncontinue adding,please input a word;back to main menu,input 0 :\n" );
while( scanf( "%s", f ) && ! ( f[0] == '0' && f[1] == 0 ) )
{
flag = 0;
for( i = 0; i < r; i++ )
{
if( strcmp( f, dic[i] ) == 0 )
{
clear();
printf( "the word %s has already existed\n",d );
flag = 1;
break;
}
}
if( flag == 0 )
{
clear();
printf( "the word %s is successfully added\n", f );
strcpy( dic[r], f );
r++;
}
printf( "\n\ncontinue adding,please input a word;back to main menu,input 0 :\n" );
}
Write( r );
sort();
clear();
return;
}
void Find( char *s )
{
char t[20];
int flag = 0;
char f[20];
int r = 0, c, i;
int temp;
p = fopen( "Data.txt", "r" );
clear();
while( fscanf( p, "%s", t ) != EOF )
{
strcpy( dic[r], t );
r++;
temp = strcmp( s, t );
if( temp == 0 )
{
c = r;
flag = 1;
}
}
Write( r );
if( flag )
{
printf( "%s's sequence number is %d!\n", s, c );
}
else
{
printf( "can not find %s!\n", s );
}
printf( "\n\ncontinue lookuping,please input a word;back to main menu,input 0 :\n" );
while( scanf( "%s", f ) && ! ( f[0] == '0' && f[1] == 0 ) )
{
flag = 0;
for( i = 0; i < r; i++ )
{
if( strcmp( f, dic[i] ) == 0 )
{
flag = 1;
c = i+1;
break;
}
}
if( flag )
{
clear();
printf( "%s's sequence number is %d!\n", f, c );
}
else
{
clear();
printf( "can not find %s!\n", f );
}
printf( "\n\ncontinue lookuping,please input a word;back to main menu,input 0 :\n" );
}
clear();
return;
}
void Work()
{
int i, way;
char d[20];
while( 1 )
{
Print();
scanf( "%d", &way );
switch( way )
{
case 1:
printf( "please input a word : " );
scanf( "%s", d );
Insert(d );
break;
case 2:
printf( "please input a word : " );
scanf( "%s", d );
Find( d );
break;
case 3:
printf( "all the words are saved in Data.txt !" );
return;
case 4:
clear();
Cheak();
}
}
}
void main()
{
Cheak();
sort();
Work();
}
展开阅读全文