- 1、本文档共15页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
(1) 求n的阶乘,这是一个比较简单的题目,有很多方法,但用递归方法是最简单的了:
#include stdlib.h
#include stdio.h
int main()
{
long factorial(long n);
long n;
scanf(%ld,n);
printf(%ld,factorial(n));
return 0;
}
long factorial(long d)//求阶乘
{
long m;
if(d0)
{
printf(d的阶乘不存在!);
}
else if(d==0||d==1)
{
m=1;
}
else
{
m=d*factorial(d-1);
}
return m;
}
(2)从一个文件读取整数,对其进行排序,然后再将排序的结果输入到原来文件当中,这是一个经常考的题目,即考你的文件操作,又考了排序,我在这里用的是选择排序
#include stdlib.h
#include stdio.h
int readtoarray(int *a,FILE *fp)//从文件里将整数读到数组里
{
int i=0;
if(fp==NULL)
{
exit(0);
}
while(fgetc(fp)!=EOF)
{
fscanf(fp,%d,a[i]);
printf(%d\n,a[i]);
i++;
}
return i;
}
void writetofile(int a[],FILE *fp,int i)//将数组写到文件里去
{
int k = 0;
if(fp==NULL)
{
exit(0);
}
while(ki)
{
fprintf(fp,%c%d, ,a[k++]);
}
}
void selectionSort(int *a,int i)//选择排序
{
int m,n;
int tmp,min;
for(m=0;m i-1;m++)
{
min=m;
for(n=m+1;n i;n++)
{
if(a[n]a[min])
min=n;
}
tmp=a[m];
a[m]=a[min];
a[min]=tmp;
}
}
int main()
{
FILE* fp,* fpwrite;
int i;
int a[10];
fp=fopen(2.txt,r);
i=readtoarray(a,fp);
fclose(fp);
selectionSort(a,i);
fpwrite=fopen(2.txt,w);
writetofile(a, fpwrite,i);
fclose(fpwrite);
return 0;
}
1,单向链表的插入,删除,逆序操作
#include stdio.h
#include stdlib.h
typedef struct Node
{
int key;
struct Node* next;
}* node;
node newNode(int k)
{
node n=(node)malloc(sizeof(node));
n-key=k;
n-next=NULL;
return n;
}
void printlist(node n)
{
if(!n)
{
printf(n is NULL list\n);
}
while(n)
{
printf(%d,n-key);
printf( );
n=n-next;
}
printf(\n);
}
node newList()
{
int k;
node head=(node)malloc(sizeof(node));;
scanf(%d,k);
if(k==0)
{
head=NULL;
return head;
}
else
{
node n=newNode(k);
head=n;
while(k)
{
scanf(%d,k);
if(k!=0)
{
node n1=newNode(k);
n-next=n1;
n=n-next;
}
}
n-next=NULL;
return head;
}
}
node insertNode(node n,int p,int k)
{
node n1=newNode(k);
node head=(n
文档评论(0)