早教吧作业答案频道 -->其他-->
希尔(shell)排序问题(1)提示用户输入数据(2)希尔排序设计要求:设计算法,首先屏幕上显示上述菜单,用户选择1时,提示用户从键盘随机输入无序元素存入数组中,至少输入10个元素
题目详情
希尔(shell)排序问题
(1)提示用户输入数据
(2)希尔排序
设计要求:设计算法,首先屏幕上显示上述菜单,用户选择1时,提示用户从键盘随机输入无序元素存入数组中,至少输入10个元素。用户选择2时,对数组中的元素进行希尔排序,要求屏幕显示每一趟插入排序结果。并且要求可以多次使用菜单进行选择。
希尔排序又称为缩小增量排序方法,把待排记录按下标的一定增量d分组,对每组记录采用直接插入排序方法进行排序,随着增量d逐渐减小,所分成的组包含的记录越来越多,到增量的值减小到1时,整个数据合为一个排好序的整体。
(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);
}//楼主要加分哈,弄了很久哦
#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].key
{
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 …