早教吧 育儿知识 作业答案 考试题库 百科 知识分享

希尔(shell)排序问题(1)提示用户输入数据(2)希尔排序设计要求:设计算法,首先屏幕上显示上述菜单,用户选择1时,提示用户从键盘随机输入无序元素存入数组中,至少输入10个元素

题目详情
希尔(shell)排序问题
(1)提示用户输入数据
(2)希尔排序
设计要求:设计算法,首先屏幕上显示上述菜单,用户选择1时,提示用户从键盘随机输入无序元素存入数组中,至少输入10个元素。用户选择2时,对数组中的元素进行希尔排序,要求屏幕显示每一趟插入排序结果。并且要求可以多次使用菜单进行选择。
希尔排序又称为缩小增量排序方法,把待排记录按下标的一定增量d分组,对每组记录采用直接插入排序方法进行排序,随着增量d逐渐减小,所分成的组包含的记录越来越多,到增量的值减小到1时,整个数据合为一个排好序的整体。
▼优质解答
答案和解析
#include
#include
#define maxsize 100
typedef int keytype;
typedef struct{
keytype key;
int other;
}recordtype;
typedef struct{
recordtype r[maxsize+1];
int length;
}table;
void insert(table *tab)
{
int i;
getchar();
printf("请输入这n个正整数:",tab->length);
scanf("%d",&tab->length);
for(i=1;i<=tab->length;i++)
{ printf("请输入第%d个数:",i);
scanf("%d",&tab->r[i] );}
printf("\n");
}
void show(table *tab)
{
int i;
for(i=1;i<=tab->length;i++)
printf("%5d",tab->r[i]);
printf("\n");
}
void shellinsertsort(table *tab)
{
int i,j,d,m=0;
printf("shell插入排序:\n");
d=tab->length/2;
while(d>=1) {
for(i=d+1;i<=tab->length;i++)
{
tab->r[0]=tab->r[i];
j=i-d;
while(tab->r[0].keyr[j].key && j>0)
{
tab->r[j+d]=tab->r[j];
j=j-d;
}
tab->r[j+d]=tab->r[0];
}
d=d/2;
printf("第%d趟:", m++);
show(tab);
}
}
void main()
{
table *tab;
int ch;
tab=(table *)malloc(sizeof(table));
printf(" ***** 菜单 ****** \n");
printf(" *************** 1.提示用户输入数据******************\n");
printf(" *************** 2.shell插入排序 ******************\n");
do{
printf("请输入要操作的数:(1)|(2):");
scanf("%d",&ch);
switch(ch)
{
case 1:insert(tab);break;
case 2:shellinsertsort(tab);break;
default:printf("输入错误,请重新输入!");break;
}}while(1);


}//楼主要加分哈,弄了很久哦
看了 希尔(shell)排序问题(...的网友还看了以下:

某市电信局对计算机拨号上网用户提供两种付费方式供用户选择:A计时制:3元/hB包月制:100元/月  2020-05-13 …

有顾客在超市买菜时把大白菜剥得只剩菜芯儿,把芹菜叶子择得干干净净。超市工作人员前去劝阻,表达最得体  2020-05-16 …

李庄村电费收取有以下两种方案供农户选择:方案一:每户每月收管理费2元,月用电不超30度每度0.5元  2020-05-22 …

在Windows XP启动过程中,可通过按一个功能键来显示一个菜单,让用户选择启动的方式(例如安全模  2020-05-23 …

简单的Shell编程练习题完成Shell程序,显示菜单,根据输入某字母来选择菜单项,来完成对应菜单  2020-07-23 …

希尔(shell)排序问题(1)提示用户输入数据(2)希尔排序设计要求:设计算法,首先屏幕上显示上  2020-07-23 …

若用户选择冻结余额宝来使用分期服务,将冻结多少金额?(1)假设用户有剩余可用消费额度400若用户选择  2020-11-06 …

大一计算机基础4.Excel中,()操作不能实现在第n行之前插入一行。A.在活动单元格中,单击右键选  2020-11-11 …

在Word中,插入“页码”不正确的方法是。A.选择菜单“插入”中的“页码”B.选择菜单“插入”中的“  2020-11-28 …

计算机基础23.Excel中,()操作不能实现在第n行之前插入一行。A.在活动单元格中,单击右键选择  2020-11-28 …