线性表
来源:互联网 发布:ubuntu下apache 2配置 编辑:程序博客网 时间:2024/06/08 17:44
/*文件名称:lab1-01.c */
/**********************************/
/*基于sequlist.h中定义的顺序表,编写算法函数reverse(sequence_list *L),实现顺序表的就地倒置。*/
#include "sequlist.h"
/*请将本函数补充完整,并进行测试*/
void reverse(sequence_list *L)
{
int i,j;
for(i=0,j=L->size-1;i<L->size/2,j>L->size/2;i++,j--)
{
int temp;
temp=L->a[i];
L->a[i]=L->a[j];
L->a[j]=temp;
}
}
int main()
{
sequence_list L; /*定义顺序表*/
input(&L); /*输入测试用例*/
print(&L); /*输出原表*/
reverse(&L); /*顺序表倒置*/
print(&L); /*输出新表*/
}
/**********************************/
/*文件名称:lab1_02.c */
/**********************************/
/*编写一个算法函数void sprit( sequence_list *L1,sequence_list *L2,sequence_list *L3),
将顺序表L1中的数据进行分类,奇数存放到存到顺序表L2中,偶数存到顺序表L3中,编写main()进行测试。
*/
#include "sequlist.h"
/*请将本函数补充完整,并进行测试*/
void sprit(sequence_list *L1,sequence_list *L2,sequence_list *L3)
{
int i;
for(i=0;i<L1->size;i++)
{
if(L1->a[i]%2==0)
L3->a[L3->size++]=L1->a[i];
else
L2->a[L2->size++]=L1->a[i];
}
}
int main()
{ sequence_list L1,L2,L3; /*定义三个顺序表*/
input(&L1); /*输入L1*/
sprit(&L1,&L2,&L3); /*对L1进行分类*/
print(&L1); /*输出L1、L2和L3*/
print(&L2);
print(&L3);
}
/*假设顺序表la与lb分别存放两个整数集合,函数inter(seqlist *la,seqlist *lb,seqlist *lc)
的功能是实现求顺序表la与lb的交集存放到顺序表lc中,请将函数补充完整. */
/**********************************/
/*文件名称:lab1_04.c */
/**********************************/
#include "sequlist.h"
/*请将本函数补充完整,并进行测试*/
void inter(sequence_list *la,sequence_list *lb,sequence_list *lc)
{
int i,j;
for(i=0; i<la->size; i++)
for(j=0; j<lb->size; j++)
{
if(lb->a[j]==la->a[i])
lc->a[lc->size++]=lb->a[j];
}
}
int main()
{
sequence_list la,lb,lc;
inputfromfile(&la,"1.txt"); /*从文件1.txt建立顺序表*/
inputfromfile(&lb,"2.txt"); /*从文件2.txt建立顺序表*/
print(&la); /*输出la*/
print(&lb); /*输出lb*/
inter(&la,&lb,&lc); /*求la与lb的交集存于lc中*/
print(&lc); /*输出lc*/
return 0;
}
#include <stdio.h>
#include <stdlib.h>
/**********************************/
/*顺序表的头文件,文件名sequlist.h*/
/**********************************/
#define MAXSIZE 100
typedef int datatype;
typedef struct
{
datatype a[MAXSIZE];
int size;
} sequence_list;
/**********************************/
/*函数名称:initseqlist() */
/*函数功能:初始化顺序表 */
/**********************************/
void initseqlist(sequence_list *L)
{
L->size=0;
}
/**********************************/
/*函数名称:input() */
/*函数功能:输入顺序表 */
/**********************************/
void input(sequence_list *L)
{
datatype x;
initseqlist(L);
printf("请输入一组数据,以0做为结束符:\n");
scanf("%d",&x);
while (x)
{
L->a[L->size++]=x;
scanf("%d",&x);
}
}
/**********************************/
/*函数名称:inputfromfile() */
/*函数功能:从文件输入顺序表 */
/**********************************/
void inputfromfile(sequence_list *L,char *f)
{
int i,x;
FILE *fp=fopen(f,"r");
L->size=0;
if (fp)
{
while ( ! feof(fp))
{
fscanf(fp,"%d",&L->a[L->size++]);
}
fclose(fp);
}
}
/**********************************/
/*函数名称:print() */
/*函数功能:输出顺序表 */
/**********************************/
void print(sequence_list *L)
{
int i;
for (i=0; i<L->size; i++)
{
printf("%5d",L->a[i]);
if ((i+1)%10==0) printf("\n");
}
printf("\n");
}
- 线性表--线性存储
- 线性表 线性结构
- 线性表
- 线性表
- 线性表
- 线性表
- 线性表
- 线性表
- 线性表
- 线性表
- 线性表
- 线性表
- 线性表
- 线性表
- 线性表
- 线性表
- 线性表
- 线性表
- 任意次方后的最后三位数
- LeetCode687. Longest Univalue Path
- 51nod 1204 Parity(并查集)
- Hbase架构与原理
- Hanoi塔问题
- 线性表
- RIPv2协议
- C语言数据结构单链队列的操作集
- jq的 $(function(){}) , document.ready 与 window.onload 的区别
- 利用python进行微信好友分析
- stored-program Computer/von Neumann Architecture 冯诺依曼体系结构
- python学习中遇到的问题整理
- Java文件创建删除复制读写以及查找盘符文件操作
- CString 变 char