首页
社区
课程
招聘
[旧帖] [讨论]DEV C++中初学者编程 共同学习者顶起来 0.00雪花
发表于: 2010-5-22 17:40 74312

[旧帖] [讨论]DEV C++中初学者编程 共同学习者顶起来 0.00雪花

2010-5-22 17:40
74312
收藏
免费 0
支持
分享
最新回复 (280)
雪    币: 21
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
51
好了 我们继续学习 上面学习到栈的例题了

中缀表达式化成后缀表达式怎么化??

中缀表达式变后缀表达式方法:
     例:15+(6*2-5)/3-8
     先变成标准中缀表达式
     ((15+(((6*2)-5)/3))-8)

     后缀表达式                           栈(用来放运算符,遇右括后弹仓至遇左括号)
                                          ((
      15                                  ((
      15                                  ((+
      15                                  ((+(((
      15 6                                ((+(((
      15 6 2                              ((+(((
      15 6 2                              ((+(((*
      15 6 2                              ((+(((* 遇)开始弹栈
      15 6 2 *                            ((+((  
      15 6 2 * 5                          ((+((
      15 6 2 * 5                          ((+((-
      15 6 2 * 5                          ((+((-  遇)开始弹栈
      15 6 2 * 5 -                        ((+(
      15 6 2 * 5 - 3                      ((+(
      15 6 2 * 5 - 3                      ((+(/
      15 6 2 * 5 - 3                      ((+(/   遇)开始弹栈
      15 6 2 * 5 - 3 /                    ((+     遇)开始弹栈
      15 6 2 * 5 - 3 / +                  (
      15 6 2 * 5 - 3 / + 8                (
      15 6 2 * 5 - 3 / + 8                (-   
      15 6 2 * 5 - 3 / + 8                (-      遇)开始弹栈
      15 6 2 * 5 - 3 / + 8 -              此结果就是后缀表达式

    自己在记事本中对齐了再看可能好一点儿 呵呵 每行一个变化。 规则是左边数字 右边运算符 遇右括号弹仓到左边消一个左括号。
    这个搞清楚了,实际上就是一个算法,后面就可写出C的运行程序将中缀表达式转换成后缀表达式。
2010-5-27 21:18
0
雪    币: 114
活跃值: (26)
能力值: ( LV4,RANK:50 )
在线值:
发帖
回帖
粉丝
52
谢谢大虾们,刚刚理解了什么是当型循环!
2010-5-27 22:27
0
雪    币: 21
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
53
后缀表达式 用栈计算表达式的值
例:上题中表达式结果为28/3

后缀表达式: 15 6 2 * 5 - 3 / + 8 -  从左向右读这个后缀表达式,放入栈S中如图示
      
        S栈                                
     15 6 2                             遇* 取2为Y 6为X   X*Y结果入栈
     15 12                              继续读后缀式
     15 12 5                            遇- 取5为Y12为X   X-Y=12-5=7 入栈
     15 7                               继续读后缀式
     15 7 3                             遇/ 取3为Y 7为X   X/Y=7/3    入栈
     15 7/3                             继续读后缀式
     15 7/3                             遇+               15+7/3     入栈
     52/3                               继续读后缀式
     52/3 8                             遇-               52/3 -8    入栈
     28/3                               结束 结果就是28/3

      将后缀表达式读入栈, 遇运算符就取出两个操作数,先出的为Y,后出栈的为X 运算: X 运算符 Y =? 将结果又压入栈中,继续直到得出结果.

     写C的源程 不知同仁中哪位有兴趣写一个出来哦!!!       
     我自己还没开始写,这两天较忙.  后面我会写一个出来.
2010-5-28 19:05
0
雪    币: 33
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
54
我怎么看那奥赛的题好多都看不懂啊,和你说的不一样
   有的语句不知道怎么写的。
2010-5-29 13:42
0
雪    币: 21
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
55
我倒 那是PASCL  这里的是C  
2010-5-29 14:05
0
雪    币: 77
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
56
看起来不错,写一个试试!
2010-5-29 20:31
0
雪    币: 33
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
57
那你买的那几本有什么用啊???
2010-5-30 14:32
0
雪    币: 21
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
58
那几本不是买的 是送的 没选择的权利 呵呵
2010-5-30 20:56
0
雪    币: 32
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
59
#include<stdio.h>
char a[1000];
int main()
{int m;
char n;
FILE *FP;
FP=freopen("in.txt","r",stdin);
freopen("out.txt","w",stdout);
for(m=0;m<100;m++)
{n=fgetc(FP);
if(n==-1)
break;
a[m]=n;
}
m--;
printf("%s,%d",a,m);
}
2010-6-2 13:50
0
雪    币: 33
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
60
#include <stdio.h>
main()
{
  FILE *FP;
  FP=freopen ("in.txt", "r" ,stdin);
  freopen("out.txt", "w", stdout);
  
  char a[100],q;
  int i;
     for (i=0;i<100;i++)
      {
       q=fgetc(FP);
       if (q==-1)  break;
       a[i]=q;
      }  
printf ("%s",a);      
      
      
}
2010-6-2 14:01
0
雪    币: 21
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
61
#include "stdio.h"
#include "stdlib.h"
#include "string.h"

int main()
{
   FILE *FP;
   FP=freopen("in.txt","r",stdin);
   freopen("out.txt","w",stdout);
   char s[100],ss;
   int i,j,k;
   
  /* 从输入文件读取100位以内的四则混合标准后缀表达式 非标准可能计算错误
     所谓标准如:(3+5)/2-5 要化成(((3+5)/2)-5) 全用小括号括起来         */
   for(i=0;i<100;i++)
    {
     ss=fgetc(FP);
     if(ss==-1) break;                   /* 读取文件错误返回值是-1  用于跳出  */
     s[i]=ss;                  
    }
   for(j=0;j<i;j++)
   printf("%c",s[j]);
   i--;
   printf("\ni=%d\n",i);printf("\ns[i+1]=%d\n",s[i+1]);
  
  /* 模拟中缀化后缀的栈操作  */
  int z=0,h=0;
  char hou[100],zan[100],x,y;
  for(z=0,j=0;j<=i;j++)                   /* i是字符个数减了1  这决定牡环次数 */
    {     
     x=s[j];
     printf("x=%c j=%d\n",x,j);           /* 用于调试检查每步是否正确完成后删 */
     if((x=='+')||(x=='-')||(x=='*')||(x=='/')||(x=='('))  /* 注意优先级      */
        {
         zan[z]=x; z++;                   /* 这里字符数组赋值用X 不能用数组   */
        }
     else if(x!=')')                      /* 三分支分别给出了三个情况分离     */
        {
         hou[h]=x;h++;               
        }  
     else
        {
          y=zan[z-1];
          while(y!='(')                   /* 这里当型循环的边界值以实例检验   */
           {hou[h]=y;z--;h++;y=zan[z-1];}  
          z--;
        }
     printf("zan[z]=%s\n",zan);
     printf("hou[h]=%s\n",hou);   
     
           
    }
   
   
   /* 输出后缀表达式  */  
   printf("The long of h=%d\n",h);
   printf("The suffix expression is : %s\n",hou);
   
}

错误一定有 望指正
2010-6-2 16:01
0
雪    币: 32
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
62
看了一下上面的程序貌似懂了一点,但还是有一些东西不能明白
比如说把栈中的运算符之类的东西怎么放到数中去,
还有就是为什么循环之后栈中的那些括号删除掉!
请老师写清楚一点!
谢谢!!!
2010-6-2 16:29
0
雪    币: 458
活跃值: (421)
能力值: ( LV9,RANK:610 )
在线值:
发帖
回帖
粉丝
63
樓主在前面講的那個猴子的問題  貌似是約瑟夫8小孩問題
http://bbs.pediy.com/showthread.php?t=106750  這是一個精簡的算法

ps。建議樓主用主流的VS2008編譯器寫程序。
八卦一下,樓主是老師? 很難得
2010-6-2 17:50
0
雪    币: 348
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
64
这个很好,非常支持持!
2010-6-2 18:01
0
雪    币: 21
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
65
谢谢楼上两位朋友支持

你的算法我看了,不错! 我后面发的那个程序中也用了这个, 只是我写的太啰嗦,漏洞也多,是为了调试和让那两个学生看懂!!我正在初步介绍数据结构和算法,但我学识太浅了,以后还望多多指点!

谢谢了!!
2010-6-2 19:47
0
雪    币: 21
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
66
佩服!!  继续细看你的算法, 妙!!!

                    w=(w+m-1)%i;  
                      printf("%d",s[w]);

我改成这样适合我的编译软件了.  结果确实是正确的,  这前一句就是想不到啊 是怎么得出来的啊

小弟愚笨  呵呵  

猜测: W相当于报数起点 W+M找到报数人 再减1就是数组脚标 对数组长度取模就够成 约瑟夫环  是这样的吗??
2010-6-2 21:08
0
雪    币: 105
活跃值: (10)
能力值: ( LV3,RANK:20 )
在线值:
发帖
回帖
粉丝
67
呵呵,好好看看哈希吧
2010-6-2 21:29
0
雪    币: 3
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
68
好。建议第一个帖子设立一个目录,不然以后帖子多了,看起来比较麻烦。
2010-6-3 12:23
0
雪    币: 32
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
69
如此巧妙的算法难得啊难得!!
如果以后用问题一定请教
2010-6-3 12:58
0
雪    币: 33
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
70
太牛了
2010-6-3 13:29
0
雪    币: 21
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
71
最近高考学考 有点忙 不能更新 望谅解
2010-6-7 07:58
0
雪    币: 21
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
72
高考学考马上又是中考 学生放假 布置了这套试题 有兴趣的朋友可试着做一做 :

自考“C语言程序设计”模拟试题一
2007年05月29日 13:52   来源:自考365
     一、填空题
  1、C语言中基本的数据类型有:______、______ 、______ .
  2、C语言中普通整型变量的类型说明符为______,在内存中占______字节,有符号普通整型的数据范围是______ .
  3、整数-35在机内的补码表示为______.
  4、执行下列语句int a=8;  a+=a-=a*a; 后,a的值是______.
  5、有如下语句:char  A[ ]={“I am a student”}; 该字符串的长度是______,A[3]=______.
  6、符号“a”和‘a’的区别是______.
  7、所谓“指针”就是______.“&”运算符的作用是______.“*”运算符的作用是______.
  8、有如下输入语句:scanf(“a=%d,b=%d,c=%d”,&a,&b,&c);为使变量a的值为1,b的值为3,c的值为2,从键盘输入数据的正确形式应是______.
  二、选择题
  1、设整型变量a为5,使b不为2的表达式是(     )。
  A. b=a/2    B. b=6-(——a)   C. b=a%2    D. b=a>3?2:1
  2、为了避免嵌套的条件分支语句if-else的二义性,C语言规定:C程序中的else总是与(     )组成配对关系。
  A. 缩排位置相同的if        B. 在其之前未配对的if
  C. 在其之前未配对的最近的if     D.同一行上的if
  3、以下程序的输出结果是(      )。
  int x=10,y=10;
  printf(“%d  %d\n”,x——,——y);
  A. 10  10      B. 9   9      C. 9   10     D. 10   9
  4、设A为存放(短)整型的一维数组,如果A的首地址为P,那么A中第i 个元素的地址为(     )。
  A.P+i*2       B.  P+(i-1)*2      C.  P+(i-1)     D.  P+i
  5、选出下列标识符中不是合法的标识符的是(     )。
  A. hot_do      B. cat1       C. _pri         D. 2ab
  6、以下程序的输出结果是(     )。
  int a=5;
  float x=3.14;
  a*=x*(‘E’ - ‘A’);
  printf(“%f\n”,(float)a);
  A. 62.000000     B. 62.800000      C. 63.000000     D. 62
  7、设有说明double(*p1)[N];其中标识符p1是(     )。
  A. N个指向double型变量的指针。
  B. 指向N个double型变量的函数指针。
  C. 一个指向由N个double型元素组成的一维数组的指针。
  D.具有N个指针元素的一维指针数组,每个元素都只能指向double型量。
  8、在C程序中有如下语句:char *func(int x,int y);它是(     )。
  A. 对函数func的定义。      B. 对函数func的调用。
  C.对函数func的原型说明。  D. 不合法的。
  9、以下程序的输出结果是(     )。
  char str[15]=“hello!”;
  printf(“%d\n”,strlen(str));
  A. 15         B. 14          C. 7           D. 6
  10、分析以下程序的输出结果是(     )。
  main()
  {int  a=5,b=-1,c;
  c=adds(a,b);
  printf(“%d”,c);
  c=adds(a,b);
  printf(“%d\n”,c);    }
  int adds(int x,int y)
  {static int m=0,n=3;
  n*=++m;
  m=n%x+y++;
  return(m);            }
  A. 2,3         B. 2,2         C. 3,2          D. 2,4
  11、下列描述中不正确的是(     )。
  A. 字符型数组中可能存放字符串。
  B. 可以对字符型数组进行整体输入、输出。
  C. 可以对整型数组进行整体输入、输出。
  D. 不能在赋值语句中通过赋值运算符“=”对字符型数组进行整体赋值。
  12、以下程序的输出结果是(     )。
  #define  f(x)   x*x
  main()
  {int a=6,b=2,c;
  c=f(a)/f(b);
  printf(“%d\n”,c);
  }
  A.  9         B.  6          C.  36           D.  18
  13、设有如下定义: int x=10,y=3,z;
  则语句printf(“%d\n”,z=(x%y,x/y)); 的输出结果是(     )。
  A. 1      B. 0       C. 4        D. 3
  14、定义如下变量和数组:int i;int x[3][3]={1,2,3,4,5,6,7,8,9};
  则语句for(i=0;i<3;i++)  printf(“%d  ”,x[i][2-i]); 的输出结果是(     )。
  A. 1  5  9           B. 1  4  7       C. 3  5  7          D. 3  6  9
  15、以下对二维数组a进行正确初始化的是(     )
  A. int a[2][3]={{1,2},{3,4},{5,6}};  B. int a[ ][3]={1,2,3,4,5,6};
  C. int a[2][ ]={1,2,3,4,5,6};             D. int a[2][ ]={{1,2},{3,4}};
  16、两次运行下面的程序,如果从键盘上分别输入6和3,则输出结果是(     )。
  int x;
  scanf(“%d”,&x);
  if(x++>5)   printf(“%d”,x);
  else   printf(“%d\n”,x - -);
  A. 7和5      B. 6和3      C. 7和4       D. 6和4
  17、设有如下定义: char *aa[2]={“abcd”,“ABCD”}; 则以下说法中正确的是(    )。
  A)aa数组成元素的值分别是“abcd”和ABCD“
  B)aa是指针变量,它指向含有两个数组元素的字符型一维数组
  C)aa数组的两个元素分别存放的是含有4个字符的一维字符数组的首地址
  D)aa数组的两个元素中各自存放了字符‘a’和‘A’的地址
  18、下列程序的输出结果是(     )。
  char *p1=“abcd”, *p2=“ABCD”, str[50]=“xyz”;
  strcpy(str+2,strcat(p1+2,p2+1));
  printf(“%s”,str);
  A. xyabcAB        B. abcABz       C. ABabcz       D. xycdBCD
  19、下列程序的输出结果是(     )。
  int a[5]={2,4,6,8,10},*P,* *k;
  p=a;  k=&p;
  printf(“%d”,*(p++));
  printf(“%d\n”,* *k);
  A. 4 4          B. 2 2        C. 2 4         D. 4 6
  20、不能把字符串:Hello!赋给数组b的语句是(     )。
  A. char b[10]={‘H’,‘e’,‘l’,‘l’,‘o’,‘!’};
  B. char b[10];  b=“Hello!”;
  C. char b[10];  strcpy(b,“Hello!”);
  D. char b[10]=“Hello!”;
  三、读程序题
  1、float f=3.1415927;
  printf(“%f,%5.4f,%3.3f”,f,f,f);
  则程序的输出结果是          .
  2、int x=6, y=7;
  printf(“%d,”,x++);
  printf(“%d\n”,++y);
  程序的输出结果是        .
  3、a=3;
  a+=(a<1)?a:1;
  printf(“%d”,a);
  结果是.
  4、for (a=1,b=1;a<=100;a++)
  { if(b>=20)   break;
  if(b%3==1)
  {b+=3;  continue;}
  b-=5; }
  程序的输出结果a的值为       .
  5、int y=1, x, *p, a[ ]={2,4,6,8,10};
  p=&a[1];
  for(x=0;x<3;x++)
  y + = * (p + x);
  printf(“%d\n”,y);
  程序的输出结果y的值是      .
  四、程序填空题
  1、从键盘上输入10个数,求其平均值。
  main()
  {int i;
  float f,sum;
  for(i=1,sum=0.0;i<11;i++)
  {        ;
  ;    }
  printf(“average=%f\n”,sum/10);             }
  2、以下程序是建立一个名为myfile的文件,并把从键盘输入的字符存入该文件,当键盘上输入结束时关闭该文件。
  #include <stdio.h>
  main()
  { FILE *fp;
  char c;
  fp=          ;
  do{
  c=getchar();
  fputs(c,fp);
  }while(c!=EOF);
  }
  3、以下程序的功能是:从键盘上输入若干个学生的成绩, 统计并输出最高成绩和最低成绩,当输入负数时结束输入。请填空。
  main()
  { float x,amax,amin;
  scanf(“%f”,&x);
  amax=x;   amin=x;
  while(            )
  { if(x>amax)    amax=x;
  if(          )     amin=x;
  scanf(“%f”,&x);                     }
  printf(“\namax=%f\namin=%f\n”,amax,amin);  }
  五、编程题
  1. 三个整数a、b、c,由键盘输入,输出其中最大的一个数。
  2.输出1900~2000年中所有的闰年。每输出3个年号换一行。(判断闰年的条件为下面二者之一:能被4整除,但不能被100整除。或者能被400整除。)
  3.请编一个函数int fun(int a),它的功能是:判断a是否是素数,若a是素数,返回1;若不是素数,返回0.A的值由主函数从键盘读入。
  4.有N个学生,每个学生的信息包括学号、性别、姓名、四门课的成绩,从键盘上输入N个学生的信息,要求输出总平均成绩最高的学生信息,包括学号、性别、姓名和平均成绩。
2010-6-13 15:09
0
雪    币: 32
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
73
今天已到!
2010-6-22 13:42
0
雪    币: 33
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
74
2010-6-22 13:45
0
雪    币: 236
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
75
谢谢 分享  一直想往 C++发展
2010-6-22 15:33
0
游客
登录 | 注册 方可回帖
返回
//