1、习题6-7 简单计算器

模拟简单运算器的工作。假设计算器只能进行加减乘除运算,运算数和结果都是整数,四种运算符的优先级相同,按从左到右的顺序计算。

输入格式

输入在一行中给出一个四则运算算式,没有空格,且至少有一个操作数。遇等号”=”说明输入结束。

输出格式:

在一行中输出算式的运算结果,或者如果除法分母为0或有非法运算符,则输出错误信息“ERROR”。

输入样例:

1+2*10-10/2=

输出样例:

10
#include<stdio.h>
int main(){
    int a,sum;
    char c;
    scanf("%d",&sum);
    while((c=getchar())!='='){
        scanf("%d",&a);
        switch(c){
            case '+':sum+=a;break;
            case '-':sum-=a;break;
            case '*':sum*=a;break;
            case '/':
                if(a==0){
                    printf("ERROR");
                    return 0;
                }
                else sum/=a;
                break;
            default:printf("ERROR");
                    return 0;
        }
    }
    printf("%d",sum);
    return 0;
}

2、习题6-8 单词首字母大写

本题目要求编写程序,输入一行字符,将每个单词的首字母改为大写后输出。所谓“单词”是指连续不含空格的字符串,各单词之间用空格分隔,空格数可以是多个。

输入格式:

输入给出一行字符。

输出格式:

在一行中输出已输入的字符,其中所有单词的首字母已改为大写。

输入样例:

How are you?

输出样例:

How Are You?

 

#include<stdio.h>
int main(){
	char ch,prev=' ';
	while((ch=getchar())!='\n'){
		if (ch>='a'&&ch<='z'&&prev==' ') ch=ch-'a'+'A';
		putchar(ch);
		prev=ch;
	}
	return 0;
}

4、习题7-8 字符串转换成十进制整数 (15 分)
输入一个以#结束的字符串,本题要求滤去所有的非十六进制字符(不分大小写),组成一个新的表示十六进制数字的字符串,然后将其转换为十进制数后输出。如果在第一个十六进制字符之前存在字符“-”,则代表该数是负数。

输入格式:
输入在一行中给出一个以#结束的非空字符串。

输出格式:
在一行中输出转换后的十进制数。题目保证输出在长整型范围内。

输入样例:
+-P-xf4+-1!#
输出样例:
-3905

#include <stdio.h>
 
int main(){
    int k=0,n=0;
    //k是输入字符串数组a的有效字符下标
    //n是筛选数组p的有效下标
    char a[80],p[80];
    int flag=0,minus =0,sum=0;
    //flag 用来标记  找到第一个输出数组P的第一个值
    
    //数据输入 
    while((a[k]=getchar()) != '#')
        k++;
 
    //数据筛选    
    for(int i=0 ;i<k ;i++){
        if(a[i]=='-' && flag==0) //如果在第一个十六进制字符之前存在字符"-"
            minus=1; 
        //滤去所有的非十六进制字符(不分大小写),组成一个新的表示十六进制数字的字符串
        if((a[i]>='0'&&a[i]<='9') || (a[i]>='a'&&a[i]<='f') || (a[i]>='A'&&a[i]<='F')){//若数据在十六进制范围内的判断条件 
            flag =1;
            p[n]=a[i];
            n++; 
        }
    }
    //新字符数组如何转化成整数
    for (int i=0 ;i<n;i++){
        if(p[i]>='0' && p[i]<='9')   //若字符在0-9之间的数值转化逻辑
            sum=sum*16 +p[i]-'0';
        else if (p[i]>='a' && p[i]<='f') //若字符在a-f之间的数值转化逻辑
            sum=sum*16 +p[i]-'a'+10;
        else if (p[i]>='A' && p[i]<='F')//若字符在A-F之间的数值转化逻辑
            sum=sum*16 +p[i]-'A'+10;
    }
    
    if(minus==1)
            sum = -sum;
 
    printf("%d",sum);      
    return 0;
}

4、习题8-7 字符串排序

输入为由空格分隔的5个非空字符串,每个字符串不包括空格、制表符、换行符等空白字符,长度小于80。

输出格式:

按照以下格式输出排序后的结果:

After sorted:
每行一个字符串

输入样例:

red yellow blue black white

输出样例:

After sorted:
black
blue
red
white
yellow

 

#include <stdio.h>
#include <string.h> // 需要用到字符串处理函数strcmp和strcpy
int main()
{
    char s[5][80];  // 存放5个字符串
    int i, j;   // 循环变量
    char temp[80];  // 用于交换字符串的临时变量
    for (i = 0; i < 5; i++) {   // 输入5个字符串
        scanf("%s", s[i]);
    }
    for (i = 0; i < 4; i++) {   // 选择排序算法
        for (j = i+1; j < 5; j++) {
            if (strcmp(s[i], s[j]) > 0) {  // 比较两个字符串的大小
                strcpy(temp, s[i]); // 交换两个字符串
                strcpy(s[i], s[j]);
                strcpy(s[j], temp);
            }
        }
    }
    for (i = 0; i < 5; i++) {   // 输出排序后的5个字符串
        printf("%s\n", s[i]);
    }
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值