zoukankan      html  css  js  c++  java
  • 一些算法题

    1、将一整数逆序后放入一数组中(要求递归实现)

    #include <stdio.h>
    
    
    void convert(int *result, int n) 
    {  
    	if(n>=10)   
    		convert(result+1, n/10);  
    	*result = n%10;  
    } 
    int main(int argc, char* argv[]) 
    { 
    	int n = 123456789;
    	int result[20]={}; 
    	convert(result, n); 
    	for(int i=0; i<9; i++)  
    		printf("%d", result[i]);
    	getchar();
    }


     2.求高于平均分的学生学号及成绩(学号和成绩人工输入)

    #include <stdio.h>
    #include <iostream>
    #include <map>
    using namespace std;
    typedef map<int, int> templatemap;
    templatemap studet ;
    void find(int &nScore) 
    {  
    	int number, score; 
    	scanf("%d", &number);  
    	if(number != 0) 
    	{  
    		scanf("%d", &score);  
    		studet[number]=score;
    		nScore +=score;
    		find(nScore);   
    	}
    } 
    int main(int argc, char* argv[]) 
    { 
    	int nScore = 0;
    	find(nScore);
    	int nAverage = nScore/(studet.size());
    	for(templatemap::iterator itr = studet.begin(); itr!=studet.end();itr++)
    	{
    		if(nAverage<itr->second)
    			cout<<"ID:"<<itr->first<<"  Score:"<<itr->second<<endl;
    	}
    	getchar();
    }

    3、递归实现回文判断(如:abcdedbca就是回文,判断一个面试者对递归理解的简单程序)

    #include <stdio.h>
    #include <iostream>
    
    int find(char *str, int n)
    { 
    	if(n<=1) 
    		return 1; 
    	if(str[0]==str[n-1]) 
    	{
    		return find(str+1, n-2); 
    	}
    	else 
    	{
    		return 0; 
    	}
    } 
    int main(int argc, char* argv[])
    { 
    	char *str = "abcdedcba"; 
    	printf("%s: %s\n", str, find(str, strlen(str)) ? "Yes" : "No"); 
    	getchar();
    } 


    4.分解成质因数(如435234=251*17*17*3*2,据说是华为笔试题)

    #include <stdio.h>
    #include <iostream>
    
    void prim(int m, int n)
    {  
    	if(m>n) 
    	{  
    		while(m%n != 0) 
    			n++; 
    		m /= n;   
    		printf("%d*", n); 
    		prim(m, n);  
    	} 
    	else
    	{
    		printf("%d", m); 
    	}
    } 
    int main(int argc, char* argv[]) 
    { 
    	int n = 100;  
    	printf("%d=", n);
    	prim(n, 2); 
    	getchar();
    } 


     


     

  • 相关阅读:
    发布TrajStat 1.4.4
    Dubbo原理解析-监控
    systemctl 命令完全指南
    Spring Boot 性能优化
    试用阿里云RDS的MySQL压缩存储引擎TokuDB
    编译安装 Centos 7 x64 + tengine.2.0.3 (实测+笔记)
    使用ssh公钥实现免密码登录
    Spring Boot Admin Reference Guide
    zookeeper集群搭建设置
    dubbo服务者配置说明
  • 原文地址:https://www.cnblogs.com/byfei/p/3112189.html
Copyright © 2011-2022 走看看