• 数据结构-字符串的统计相关操作


    统计字符串的相关操作

    统计字符出现次数

    /*统计串S中字符的种类和个数*/
    #include<cstring>
    #include<iostream>
    using namespace std;
    
    
    #define OK 1
    #define ERROR 0
    #define OVERFLOW -2
    typedef int Status;
    #define MAXSTRLEN 255   		//用户可在255以内定义最长串长
    //typedef char SString[MAXSTRLEN+1];		//0号单元存放串的长度
    
    typedef struct{   
       char ch[MAXSTRLEN+1];				//若是非空串,则按串长分配存储区,否则ch为NULL   
       int length;				//串长度   
    }SString; 
    
    typedef struct {
         char ch;//存放出现的字符 
         int num;//出现的个数     
     } mytype;
    Status StrAssign(SString &T, char *chars) { //生成一个其值等于chars的串T
    	int i;
    	if (strlen(chars) > MAXSTRLEN)
    		return ERROR;
    	else {
    		T.length = strlen(chars);
    		for (i = 1; i <= T.length; i++)
    			T.ch[i] = *(chars + i - 1);
    		return OK;
    	}
    }
    void StrAnalyze(SString S)//统计串S中字符的种类和个数
    {char c;
      mytype T[20]; //用结构数组T存储统计结果
     int i,j;
     for (i=0;i<=20;i++) {T[i].ch='',T[i].num=0;};
      for(i=1;i<=S.length;i++)
      {
        c=S.ch[i];j=0;
        while(T[j].ch&&T[j].ch!=c) j++; //查找当前字符c是否已记录过
        if(T[j].ch) T[j].num++;
        else {T[j].ch=c;T[j].num++;}
      }//for 
      for(j=0;T[j].ch;j++)
       cout<<T[j].ch<<":"<<T[j].num<<endl;
    }//StrAnalyze
    
    int  main()
    {SString S;
    char *T="sasdddas1111as";
    StrAssign(S,T);
    StrAnalyze(S);
    return 0;
    }
    
    
    
    

    统计字符出现次数的另一种情况

    /*统计串S中字符的种类和个数*/
    #include<cstring>
    #include<iostream>
    using namespace std;
    
    void count()//统计输入字符串中数字字符和字母字符的个数。
    { int i,num[36];
      char ch;
      for (i=0;i<36;i++) num[i]=0;
      while ((ch=getchar())!='#')
      {
      if('0'<=ch&&ch<='9') 
         {i=int(ch)-48;num[i]++;}
       else if('A'<=ch&&ch<='Z')
          {i=ch-65+10;num[i]++;}}
      for(i=0;i<10;i++)
    	  cout<<"数字"<<i<<"的个数"<<num[i]<<endl;
      for(i=10;i<36;i++)   
        cout<<"字母"<<char(i+55)<<"的个数"<<num[i]<<endl;
    }
    int main()
    {cout<<"请输入字符串:('#'结束)"; 
    count();
    }
    
    
    
    
    

    排正负(与本章主题无关)

    #include<iostream>
    using namespace std;
    
    void Arrange(int A[],int n){
    	int i= 0,j=n-1,x,k=0;
    	while(i<j){
    		while(i<j&&A[i]>0) i++;
    		while(i<j&&A[j]<0) j--;
    		if(i<j){
    			x=A[i];
    			A[i]=A[j];
    			A[j]=x;
    			i++;
    			j--;
    		}
    	}
    	
    	while(k<n){
    		cout<<A[k]<<" ";
    		k++;
    	}
    } 
    int main(){
    	int a[100];
    	int i=0,x,n;
    	cout<<"输入数组的个数:" ;
    	cin>>n;
    	while(i<n){
    		cin>>x;
    		a[i++]=x;
    	}
    	Arrange(a,n);
    
    
    }
    
    
  • 相关阅读:
    iOS开发 -------- transform属性(形变)
    iOS开发 -------- UITableView的编辑
    iOS开发 -------- 九宫格坐标计算
    Alcatraz的安装和使用
    Python实现简单抓取功能
    预备作业:课程基础
    预备作业:课程基础
    预备作业
    oracle常用命令总结
    在Linux下写一个线程池以及线程池的一些用法和注意点
  • 原文地址:https://www.cnblogs.com/ygjzs/p/11789295.html
Copyright © 2020-2023  润新知