C语言,编程入门(3)

2019-03-15 19:19

for(i=0;i<3;i++) sum=sum+a[i][i];

printf(\ }

【程序34】

题目:有一个已经排好序的数组。现输入一

个数,要求按原来的规律将它插入数组中。 1. 程序分析:首先判断此数是否大于最后一

个数,然后再考虑插入中间的数的情况,插

入后 此元素之后的数,依次后移一个位置。 2.程序源代码:

main() { int a[11]={1,4,6,9,13,16,19,28,40,100}; int temp1,temp2,number,end,i,j; printf(\ for(i=0;i<10;i++) printf(\ printf(\ printf(\ scanf(\ end=a[9]; if(number>end) a[10]=number; else {for(i=0;i<10;i++) { if(a[i]>number) {temp1=a[i]; a[i]=number; for(j=i+1;j<11;j++) {temp2=a[j]; a[j]=temp1; temp1=temp2; } break; } } } for(i=0;i<11;i++) printf(\ } 【程序35】

题目:将一个数组逆序输出。

1.程序分析:用第一个与最后一个交换。 2.程序源代码: #define N 5 main() { int a[N]={9,6,5,4,1},i,temp; printf(\

for(i=0;i

{temp=a[i]; a[i]=a[N-i-1]; a[N-i-1]=temp; } printf(\ for(i=0;i

printf(\ } }

{int i;

for(i=0;i<9;i++)

scanf(\ scanf(\ } 【程序37】

max_min(array) 题目:输入3个数a,b,c,按大小顺序输出。

1.程序分析:利用指针方法。

2.程序源代码:

/*pointer*/ main() { int n1,n2,n3; int *pointer1,*pointer2,*pointer3; printf(\ scanf(\ pointer1=&n1; pointer2=&n2; pointer3=&n3; if(n1>n2) swap(pointer1,pointer2); if(n1>n3) swap(pointer1,pointer3); if(n2>n3) swap(pointer2,pointer3); printf(\sorted numbers are:%d,%d,%d\\n\ } swap(p1,p2) int *p1,*p2; {int p; p=*p1;*p1=*p2;*p2=p; } 【程序38】 题目:输入数组,最大的与第一个元素交换,最小的与最后一个元素交换,输出数组。 1.程序分析: 2.程序源代码:

main() { int number[10]; input(number); max_min(number); output(number); } input(number) int number[10]; int array[10]; {int *max,*min,k,l; int *p,*arr_end; arr_end=array+10; max=min=array; for(p=array+1;p*max) max=p; else if(*p<*min) min=p; k=*max; l=*min; *p=array[0];array[0]=l;l=*p; *p=array[9];array[9]=k;k=*p; return; } output(array) int array[10]; { int *p; for(p=array;p

main() { int number[20],n,m,i; printf(\ scanf(\ printf(\ scanf(\ for(i=0;i

move(number,n,m); for(i=0;i

printf(\ printf(\ }

move(array,n,m) int n,m,array[20]; {

int *p,array_end;

array_end=*(array+n-1); for(p=array+n-1;p>array;p--) *p=*(p-1);

*array=array_end; m--;

if(m>0) move(array,n,m); }

【程序40】

题目:有n个人围成一圈,顺序排号。从第一个人开始报数(从1到3报数),凡报到3的人退出 圈子,问最后留下的是原来第几号的那位。

1. 程序分析: 2.程序源代码: #define nmax 50 main() {

int i,k,m,n,num[nmax],*p;

printf(\ scanf(\ p=num;

for(i=0;i

while(m

if(*(p+i)!=0) k++; if(k==3) { *(p+i)=0; k=0; m++; }

i++;

if(i==n) i=0; }

while(*p==0) p++;

printf(\ }

【程序41】

题目:写一个函数,求一个字符串的长度,在main函数中输入字符串,并输出其长度。 1.程序分析: 2.程序源代码: main( ) {

int len;

char *str[20];

printf(\ scanf(\ len=length(str);

printf(\ }

length(p) char *p; { int n; n=0;

while(*p!='\\0') {

n++; p++; }

return n; }

【程序42】 题目:编写input()和output()函数输入,输出5个学生的数据记录。 1.程序分析: 2.程序源代码: #define N 5 struct student { char num[6]; char name[8]; int score[4]; } stu[N];

input(stu)

struct student stu[]; { int i,j;

for(i=0;i

{ printf(\ printf(\

scanf(\ printf(\

scanf(\ for(j=0;j<3;j++)

{ printf(\

scanf(\ }

printf(\ } }

print(stu)

struct student stu[]; { int i,j;

printf(\ for(i=0;i

{ printf(\ for(j=0;j<3;j++)

printf(\ printf(\ } }

main() {

input(); print(); }

【程序43】

题目:放松一下,算一道简单的题目。 1.程序分析: 2.程序源代码: main() {

int i,n;

for(i=1;i<5;i++) { n=0; if(i!=1) n=n+1;

if(i==3) n=n+1; if(i==4) n=n+1; if(i!=4) n=n+1; if(n==3)

printf(\ } }

【程序44】

题目:编写一个函数,输入n为偶数时,调用函数求1/2+1/4+...+1/n,当输入n为奇数时,调用函数1/1+1/3+...+1/n(利用指针函数) 1.程序分析: 2.程序源代码: main()

#include \ main() {

float peven(),podd(),dcall(); float sum; int n; while (1) {

scanf(\ if(n>1) break; }

if(n%2==0) {

printf(\ sum=dcall(peven,n); } else {

printf(\ sum=dcall(podd,n); }

printf(\ }

float peven(int n) {

float s; int i; s=1;

for(i=2;i<=n;i+=2) s+=1/(float)i; return(s); }

float podd(n) int n; {

float s; int i; s=0;

for(i=1;i<=n;i+=2) s+=1/(float)i; return(s); }

float dcall(fp,n) float (*fp)(); int n; {

float s; s=(*fp)(n); return(s); }

【程序44】

题目:找到年龄最大的人,并输出。请找出程序中有什么问题。 1.程序分析: 2.程序源代码: #define N 4

#include \ static struct man { char name[20]; int age; }

person[N]={\,22}; main()

{struct man *q,*p; int i,m=0; p=person;

for (i=0;iage)

q=p++; m=q->age;}

printf(\ }

【程序45】

题目:字符串排序。 1.程序分析: 2.程序源代码: main() {

char *str1[20],*str2[20],*str3[20]; char swap();

printf(\ scanf(\ scanf(\ scanf(\

if(strcmp(str1,str2)>0) swap(str1,str2); if(strcmp(str1,str3)>0) swap(str1,str3); if(strcmp(str2,str3)>0) swap(str2,str3); printf(\

printf(\ }

char swap(p1,p2) char *p1,*p2; {

char *p[20];

strcpy(p,p1);strcpy(p1,p2);strcpy(p2,p); }

【程序46】

题目:海滩上有一堆桃子,五只猴子来分。第一只猴子把这堆桃子凭据分为五份,多了一个,这只猴子把多的一个扔入海中,拿走了一份。第二只猴子把剩下的桃子又平均分成五份,又多了一个,它同样把多的一个扔入海中,拿走了一份,第三、第四、第五只猴子都是这样做的,问海滩上原来最少有多少个桃子? 1.程序分析: 2.程序源代码: main()

{int i,m,j,k,count; for(i=4;i<10000;i+=4)


C语言,编程入门(3).doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:用友NC系统成本核算操作手册

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: