c语言冒泡排序法问题(新手)
输入8个人的名字,再用冒泡排序法排序后输出,程序编译正常。但运行时,在输出排序后的结果后windows提示程序停止工作#include<stdio.h>#include<...
输入8个人的名字,再用冒泡排序法排序后输出,程序编译正常。但运行时,在输出排序后的结果后windows提示程序停止工作
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define k 2
void InputName(char StudName[][8]){
int i;
for(i=0;i<8;i++){
gets(StudName[i]);
}
}
void OutputName(char StudName[][8]){
int i;
for(i=0;i<8;i++){
puts(StudName[i]);
}
}
void BubbleSort(char StudName[][8]){
char n[8];
int i,j;
for(i=0;i<8;i++){
for(j=0;j<8-i;j++){
if((strcmp(StudName[j],StudName[j+1])>0)){
strcpy(n,StudName[j]);
strcpy(StudName[j],StudName[j+1]);
strcpy(StudName[j+1],n);
}
}
}
}
void main(){
char StudName[k][8];
InputName(StudName);
BubbleSort(StudName);
OutputName(StudName);
} 展开
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define k 2
void InputName(char StudName[][8]){
int i;
for(i=0;i<8;i++){
gets(StudName[i]);
}
}
void OutputName(char StudName[][8]){
int i;
for(i=0;i<8;i++){
puts(StudName[i]);
}
}
void BubbleSort(char StudName[][8]){
char n[8];
int i,j;
for(i=0;i<8;i++){
for(j=0;j<8-i;j++){
if((strcmp(StudName[j],StudName[j+1])>0)){
strcpy(n,StudName[j]);
strcpy(StudName[j],StudName[j+1]);
strcpy(StudName[j+1],n);
}
}
}
}
void main(){
char StudName[k][8];
InputName(StudName);
BubbleSort(StudName);
OutputName(StudName);
} 展开
2个回答
展开全部
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define k 20 //错误在这里,你开始2,太小了,设置大一点,就可以了
void InputName(char StudName[][8]){
int i;
for(i=0;i<8;i++){
gets(StudName[i]);
}
}
void OutputName(char StudName[][8]){
int i;
for(i=0;i<8;i++){
puts(StudName[i]);
}
}
void BubbleSort(char StudName[][8]){
char n[8];
int i,j;
for(i=0;i<8;i++){
for(j=0;j<8-i;j++){
if((strcmp(StudName[j],StudName[j+1])>0)){
strcpy(n,StudName[j]);
strcpy(StudName[j],StudName[j+1]);
strcpy(StudName[j+1],n);
}
}
}
}
void main(){
char StudName[k][8];
InputName(StudName);
BubbleSort(StudName);
OutputName(StudName);
}
#include <string.h>
#include <stdlib.h>
#define k 20 //错误在这里,你开始2,太小了,设置大一点,就可以了
void InputName(char StudName[][8]){
int i;
for(i=0;i<8;i++){
gets(StudName[i]);
}
}
void OutputName(char StudName[][8]){
int i;
for(i=0;i<8;i++){
puts(StudName[i]);
}
}
void BubbleSort(char StudName[][8]){
char n[8];
int i,j;
for(i=0;i<8;i++){
for(j=0;j<8-i;j++){
if((strcmp(StudName[j],StudName[j+1])>0)){
strcpy(n,StudName[j]);
strcpy(StudName[j],StudName[j+1]);
strcpy(StudName[j+1],n);
}
}
}
}
void main(){
char StudName[k][8];
InputName(StudName);
BubbleSort(StudName);
OutputName(StudName);
}
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询