c语言难点透彻分析

常用字符串函数列表如下,要会自己实现: 数据挖掘实验室

函数作用 函数调用形式 备注
字符串拷贝函数strcpy(char*,char *)后者拷贝到前者
字符串追加函数strcat(char*,char *)后者追加到前者后,返回前者,因此前者空间要足够大
字符串比较函数strcmp(char*,char *)前者等于、小于、大于后者时,返回0、正值、负值。注意,不是比较长度,是比较字符ASCII码的大小,可用于按姓名字母排序等。
字符串长度strlen(char *)返回字符串的长度,不包括"".转义字符算一个字符。
字符串型->整型atoi(char *)
整型->字符串型itoa(int,char *,int)做课设时挺有用的
sprintf(char *,格式化输入)赋给字符串,而不打印出来。课设时用也比较方便

注:对字符串是不允许做==或!=的运算的,只能用字符串比较函数 数据挖掘研究院

指针: 数据挖掘研究院

指针可以说是C语言中最关键的地方了,其实这个“指针”的名字对于这个概念的理解 是十分形象的。首先要知道,指针变量的值(即指针变量中存放的值)是指针(即地址)。指针变量定义形式中:基本类型 *指针变量名 中的“*”代表的是这是一个指向该基本类型的指针变量,而不是内容的意思。在以后使用的时候,如*ptr=a时,“*”才表示ptr所指向的地址里放的内 容是a。

数据挖掘交友

指针比较典型又简单的一应用例子是两数互换,看下面的程序, 数据挖掘实验室

swap(int c,int d)
{
int t;
t=c;
c=d;
d=t;
}
main()
{
int a=2,b=3;
swap(a,b);
printf(“%d,%d”,a,b);
}

这是不能实现a和b的数值互换的,实际上只是形参在这个函数中换来换去,对实参没什么影响。现在,用指针类型的数据做为参数的话,更改如下:

swap(#3333FF *p1,int *p2)
{
int t;
t=*p1;
*p1=*p2;
*p2=t;
}
main()
{
int a=2,b=3;
int *ptr1,*ptr2;
ptr1=&a;
ptr2=&b;
swap(prt1,ptr2);
printf(“%d,%d”,a,b);
}

这样在swap中就把p1,p2 的内容给换了,即把a,b的值互换了。 数据挖掘工具

指针可以执行增、减运算,结合++运算符的法则,我们可以看到: 数据挖掘工具

*++s

取指针变量加1以后的内容 数据挖掘交友

*s++ 取指针变量所指内容后s再加1
(*s)++ 指针变量指的内容加1

指针和数组实际上几乎是一样的,数组名可以看成是一个常量指针,一维数组中ptr=&b[0]则下面的表示法是等价的:

a[3]等价于*(a+3)
ptr[3]等价于*(ptr+3)
数据挖掘实验室

下面看一个用指针来自己实现atoi(字符串型->整型)函数: 数据挖掘研究院

int atoi(char *s)
{
int sign=1,m=0;
if(*s=="+"||*s=="-") /*判断是否有符号*/
sign=(*s++=="+")?1:-1; /*用到三目运算符*/
while(*s!="") /*对每一个字符进行操作*/
   {
   m=m*10+(*s-"0");
   s++; /*指向下一个字符*/
   }
return m*sign;
}

指向多维数组的指针变量也是一个比较广泛的运用。例如数组a[3][4],a代表的实际是整个二维数组的首地址,即第0行的首地址,也就是一个指针变量。而a+1就不是简单的在数值上加上1了,它代表的不是a[0][1],而是第1行的首地址,&a[1][0]。

指针变量常用的用途还有把指针作为参数传递给其他函数,即指向函数的指针
看下面的几行代码:

void Input(ST *);
void Output(ST *);
void Bubble(ST *);
void Find(ST *);
void Failure(ST *);
/*函数声明:这五个函数都是以一个指向ST型(事先定义过)结构的指针变量作为参数,无返回值。*/

void (*process[5])(ST *)={Input,Output,Bubble,Find,Failure};
/*process被调用时提供5种功能不同的函数共选择(指向函数的指针数组)*/

printf(" Choose: ?");
scanf("%d",&choice);
if(choice>=0&&choice<=4)
(*process[choice])(a); /*调用相应的函数实现不同功能*;/

总之,指针的应用是非常灵活和广泛的,不是三言两语能说完的,上面几个小例子只是个引子,实际编程中,会逐渐发现运用指针所能带来的便利和高效率。 数据挖掘实验室

文件: 数据挖掘工具

函数调用形式 说明
fopen("路径","打开方式")打开文件
fclose(FILE *)防止之后被误用
fgetc(FILE *)从文件中读取一个字符
fputc(ch,FILE *)把ch代表的字符写入这个文件里
fgets(FILE *)从文件中读取一行
fputs(FILE *)把一行写入文件中
fprintf(FILE *,"格式字符串",输出表列)把数据写入文件
fscanf(FILE *,"格式字符串",输入表列)从文件中读取
fwrite(地址,sizeof(),n,FILE *)把地址中n个sizeof大的数据写入文件里
fread(地址,sizeof(),n,FILE *)把文件中n个sizeof大的数据读到地址里
rewind(FILE *)把文件指针拨回到文件头
fseek(FILE *,x,0/1/2)移动文件指针。第二个参数是位移量,0代表从头移,1代表从当前位置移,2代表从文件尾移。
feof(FILE *)判断是否到了文件末尾
数据挖掘研究院
文件打开方式 说明
r 打开只能读的文件
w 建立供写入的文件,如果已存在就抹去原有数据
a 打开或建立一个把数据追加到文件尾的文件
r+ 打开用于更新数据的文件
w+ 建立用于更新数据的文件,如果已存在就抹去原有数据
a+ 打开或建立用于更新数据的文件,数据追加到文件尾

注:以上用于文本文件的操作,如果是二进制文件就在上述字母后加“b”。 数据挖掘实验室

我们用文件最大的目的就是能让数据保存下来。因此在要用文件中数据的时候,就是要 把数据读到一个结构(一般保存数据多用结构,便于管理)中去,再对结构进行操作即可。例如,文件aa.data中存储的是30个学生的成绩等信息,要遍历 这些信息,对其进行成绩输出、排序、查找等工作时,我们就把这些信息先读入到一个结构数组中,再对这个数组进行操作。如下例:

数据挖掘实验室

#include<stdio.h>
#include<stdlib.h>
#define N 30

typedef struct student /*定义储存学生成绩信息的数组*/
{
char *name;
int chinese;
int maths;
int phy;
int total;
}ST;
数据挖掘实验室

main()
{
ST a[N]; /*存储N个学生信息的数组*/
FILE *fp;
void (*process[3])(ST *)={Output,Bubble,Find}; /*实现相关功能的三个函数*/
int choice,i=0;
Show();
printf(" Choose: ?");
scanf("%d",&choice);
while(choice>=0&&choice<=2)
   {
   fp=fopen("aa.dat","rb");
   for(i=0;i<N;i++)
      fread(&a[i],sizeof(ST),1,fp); /*把文件中储存的信息逐个读到数组中去*/
   fclose(fp);
   (*process[choice])(a); /*前面提到的指向函数的指针,选择操作*/
   printf(" ");
   Show();
   printf(" ?");
   scanf("%d",&choice);
   }
}
数据挖掘实验室

void Show()
{
printf(" ****Choices:**** 0.Display the data form 1.Bubble it according to the total score 2.Search 3.Quit! ");
}
数据挖掘研究院

void Output(ST *a) /*将文件中存储的信息逐个输出*/
{
int i,t=0;
printf("Name Chinese Maths Physics Total ");
for(i=0;i<N;i++)
   {
   t=a[i].chinese+a[i].maths+a[i].phy;
   a[i].total=t;
   printf("%4s%8d%8d%8d%8d ",a[i].name,a[i].chinese,a[i].maths,a[i].phy,a[i].total);
   }
}
数据挖掘实验室

void Bubble(ST *a) /*对数组进行排序,并输出结果*/
{
int i,pass;
ST m;
for(pass=0;pass<N-1;pass++)
   for(i=0;i<N-1;i++)
      if(a[i].total<a[i+1].total)
         {
         m=a[i]; /*结构互换*/
         a[i]=a[i+1];
         a[i+1]=m;
         }
Output(a);
}

数据挖掘工具

void Find(ST *a)
{
int i,t=1;
char m[20];
printf(" Enter the name you want:");
scanf("%s",m);
for(i=0;i<N;i++)
   if(!strcmp(m,a[i].name)) /*根据姓名匹配情况输出查找结果*/
   {
   printf(" The result is: %s, Chinese:%d, Maths:%d,     Physics:%d,Total:%d ",m,a[i].chinese,a[i].maths,a[i].phy,a[i].total);
   t=0;
   }
if(t)
   printf(" The name is not in the list! ");
}
数据挖掘工具

[数据挖掘专家] [数据挖掘研究院] [数据挖掘论坛] [数据挖掘实验室]
上一篇:c语言难点透彻分析
下一篇:c语言难点透彻分析
最新评论共有 0 位网友发表了评论 , 查看所有评论
发表评论( 不能超过250字,需审核,请自觉遵守互联网相关政策法规。 )
匿名?
数据挖掘网站导航 数据挖掘论坛导航
  • 数据挖掘工具
  • 数据挖掘论坛
  • DataCruncher - Cognos
  • MineSet - MathSoft
  • Intelligent Miner - GainSmarts
  • Sqlserver - SAS - Clementine
  • CART - Weka - WizSoft
  • NeuroShell - ModelQuest
  • data mining tools - Darwin
  • 数据挖掘交友
  • 数据挖掘博客
  • 数据挖掘工具
  • 数据挖掘资源
  • 数据挖掘技术算法
  • 数据挖掘相关期刊、会议
  • 研究院联盟合作专区
  • 数据挖掘基础与相关技术
  • 数据挖掘厂商与就业
  • 数据挖掘研究者乐园
  • 知名厂商数据挖掘工具资料
  • 国内数据挖掘实验室
  • Foreign Data Mining Lab
  • 热点关注
  • 挑战C#学习的最快速度
  • C#模仿QQ截图功能
  • C# 关于开机自动运行程序方式之一
  • 第一章 C#简介
  • 利用C#实现分布式数据库查询
  • Visual Studio 2005 Hands-On Tutorial - P
  • C#入门代码
  • .NET架构与模式探索
  • 用C#代码编写的SN快速输入工具
  • C# 关于开机自动运行程序方式之一
  • 论坛最新话题
  • Foundations of Statistical Natural Langu
  • Game Theory meet Data Mining: A Recent P
  • System Building: How does it help or hin
  • 数据挖掘与Clementine培训
  • 新手报到
  • 求 SASEM 客户流失预测分析
  • 数据挖掘工程师/搜索研究院—北京——无线
  • 数据挖掘入门介绍(如何着手数据挖掘)
  • Information Overload Survey Results
  • The INEX 2005 Workshop on Element Retrie
  • 相关资讯
  • 彻底剖析C# 2.0泛型类的创建和使用
  • 对C# 2.0中匿名方法的怀疑分析
  • EasySP管理解决方案基于Microsoft .NET架构
  • .NET架构与模式探索
  • .NET架构的核心开发技术
  • 用C#代码编写的SN快速输入工具
  • C#链接数据库技巧
  • C#设计模式编程之抽象工厂模式新解
  • 第一章 C#简介
  • 第七章 异常处理
  • 数据挖掘实验室资料
  • 数据挖掘博客地址
  • 数据挖掘实验室网站地址
  • Prepare for Medicare audits by using dat
  • 注册成为SAS用户与爱好者俱乐部会员
  • 水南梅
  • 明日烟
  • 新人报道
  • 下载
  • 厦门服务器托管,450元/月—0592-5177319 高
  • 买空间送域名--0592-5177319 高静