科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道基础软件C语言程序开发经典实例之八

C语言程序开发经典实例之八

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

编写input()和output()函数输入,输出5个学生的数据记录 。

作者:佚名 来源:唯c世界 2007年10月28日

关键字: Linux

  • 评论
  • 分享微博
  • 分享邮件
【程序74】

  题目:连接两个链表。

  1.程序分析:

  2.程序源代码:

#include "stdlib.h"
#include "stdio.h"
struct list
{
 int data;
 struct list *next;
};
typedef struct list node;
typedef node *link;
link delete_node(link pointer,link tmp)
{
 if (tmp==NULL) /*delete first node*/
  return pointer->next;
 else
 {
  if(tmp->next->next==NULL)/*delete last node*/
   tmp->next=NULL;
  else /*delete the other node*/
   tmp->next=tmp->next->next;
  return pointer;
 }
}
void selection_sort(link pointer,int num)
{
 link tmp,btmp;
 int i,min;
 for(i=0;i<num;i++)
 {
  tmp=pointer;
  min=tmp->data;
  btmp=NULL;
  while(tmp->next)
  {
   if(min>tmp->next->data)
   {
    min=tmp->next->data;
    btmp=tmp;
   }
   tmp=tmp->next;
  }
  printf("\40: %d\n",min);
  pointer=delete_node(pointer,btmp);
 }
}
link create_list(int array[],int num)
{
 link tmp1,tmp2,pointer;
 int i;
 pointer=(link)malloc(sizeof(node));
 pointer->data=array[0];
 tmp1=pointer;
 for(i=1;i<num;i++)
 {
  tmp2=(link)malloc(sizeof(node));
  tmp2->next=NULL;
  tmp2->data=array[i];
  tmp1->next=tmp2;
  tmp1=tmp1->next;
 }
 return pointer;
}
link concatenate(link pointer1,link pointer2)
{
 link tmp;
 tmp=pointer1;
 while(tmp->next)
  tmp=tmp->next;
 tmp->next=pointer2;
 return pointer1;
}
void main(void)
{
 int arr1[]={3,12,8,9,11};
 link ptr;
 ptr=create_list(arr1,5);
 selection_sort(ptr,5);
}


  【程序75】

  题目:放松一下,算一道简单的题目。

  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("zhu hao shi de shi:%c",64+i);
 }
}

  【程序76】

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

  1.程序分析:

  2.程序源代码:

main()
#include "stdio.h"
main()
{
float peven(),podd(),dcall();
float sum;
int n;
while (1)
{
 scanf("%d",&n);
 if(n>1)
  break;
}
if(n%2==0)
{
 printf("Even=");
 sum=dcall(peven,n);
}
else
{
 printf("Odd=");
 sum=dcall(podd,n);
}
printf("%f",sum);
}
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);
}
    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章