约瑟夫环问题

3.约瑟夫环问题

  1 #include<stdio.h>
  2 #include<stdlib.h>
  3 #define  MAXSIZE  30
  4 typedef int DataType;
  5 
  6 typedef  struct  node 
  7 {   
  8     DataType  data[MAXSIZE];
  9     int  length;
 10 } SeqList,* PSeqList;
 11 //typedef SeqList* PSeqList;
 12 
 13 
 14 PSeqList  Init_SeqList( );
 15 PSeqList  Create_SeqList(PSeqList PL);
 16 int josephus_SeqList (PSeqList  josephus_seq, int s, int m);
 17 int Delete_SeqList(PSeqList PL,int i);
 18 Print_SeqList(PSeqList PL);
 19 
 20 main()
 21 {
 22    int t=1;
 23    int s,m;
 24    int op;
 25    //DataType x;
 26    //int flag;
 27    //int l;
 28    PSeqList PL;
 29    
 30          
 31    while(t)
 32        {
 33             printf("\n\n\n\n");
 34             printf("\t\t\t---顺序表---\n");
 35             printf("\n\t\t\t*******************************************");
 36             printf("\n\t\t\t*          1---初始化及创建               *");
 37             printf("\n\t\t\t*          2---约瑟夫环                   *");            
 38             printf("\n\t\t\t*          0---退     出                  *");
 39             printf("\n\t\t\t*******************************************");
 40             printf("\t\t\t请选择菜单号(0--2):");
 41             scanf("%d",&op);
 42             switch(op)
 43             {
 44    
 45                 case 1:
 46                     PL=Init_SeqList();//初始化顺序表
 47                     PL=Create_SeqList(PL);
 48                     printf("新创建的顺序表为:\n");
 49                     Print_SeqList(PL);
 50                     break;
 51                     
 52                 case 2:
 53                     printf("请输入s和m的值:\n");
 54                     scanf("%d,%d",&s,&m);
 55                     josephus_SeqList (PL, s, m);
 56 
 57                     
 58                     break;
 59 
 60                 
 61                 case 0:
 62                       t=0;
 63                       printf("\n\t\t\t程序结束!\n");
 64                       break;
 65           
 66                 default: 
 67                     printf("\n\t\t\t\t输入错误!请重新输入!\n");
 68                     break;
 69 
 70               }
 71                    
 72         }
 73 
 74 
 75 }
 76 
 77 
 78 
 79 PSeqList  Init_SeqList(void)
 80 {  /*创建一顺序表,入口参数无,返回一个指向顺序表的指针,指针值为零表示分配空间失败*/
 81    PSeqList  PL;
 82    PL=( PSeqList )malloc(sizeof(SeqList)); 
 83    if (PL)       /*若PL=0表示分配失败*/
 84         PL->length=0;     
 85    return (PL);
 86 } 
 87 
 88 PSeqList  Create_SeqList(PSeqList PL)
 89 {
 90        int i,n;
 91        printf("请输入需初始化的元素个数\n");
 92        scanf("%d",&n);
 93        printf("请输入%d个整数,中间用空格隔开:\n",n);
 94        for(i=0;i<n;i++)//输入10个整数
 95        { 
 96            scanf("%d",&PL->data[i]);
 97            PL->length++; 
 98        }
 99        return (PL);
100 
101 
102 }
103 
104 int josephus_SeqList (PSeqList  josephus_seq, int s, int m)
105 {  
106     int s1,i,w;
107     if (!josephus_seq->length)
108     {
109          printf("表中无元素"); 
110          return (0);
111     }
112     s1=s-1;   /*data数组中下标从0开始*/
113     printf("输出约瑟夫序列:");
114    
115     for(i=josephus_seq->length; i>0; i--)
116     {  
117        s1=(s1+m-1)%i;   /*找到出列元素的下标*/
118        w=josephus_seq->data[s1];
119        printf("%d\t", w);
120        Delete_SeqList(josephus_seq,s1+1);  //
121     } 
122     return(1);//
123 }
124 
125 
126 int Delete_SeqList(PSeqList PL,int i)
127 {  /*顺序表删除,入口参数:顺序表指针,删除元素位置,返回标志1表示成功,0表示删除位置不合法,-1表示表不存在*/
128     int  j;
129     if (! PL)
130     { 
131        printf("表不存在"); 
132        return(-1);    /*表不存在,不能删除元素*/
133     }
134     if(i<1 || i> PL -> length)  /*检查删除位置的合法性*/
135     {  
136         printf ("删除位置不合法"); 
137         return(0);
138     } 
139     //*x= PL ->data[i-1];
140     for(j=i;j< PL -> length; j++)
141          PL ->data[j-1]=PL ->data[j];    //向上移动
142     PL-> length --;    
143     return (1);        /*删除成功*/
144 }
145 
146 
147 Print_SeqList(PSeqList PL)
148 {
149     int i;
150     if(!PL)
151     {
152         printf("无此顺序表");
153         return -1;
154     }
155     if(PL->length==0)
156     {
157         printf("空表");
158         return 0;
159     }
160 
161     printf("顺序表的长度为%d\n",PL->length);
162     printf("顺序表的各元素值为:");
163     for(i=0;i<=PL->length-1;i++)
164         printf("%4d",PL->data[i]);
165     return 1;
166 
167 }

 

posted @ 2017-03-20 10:56  不忘_初芯  阅读(261)  评论(0编辑  收藏  举报