【C语言答案】第五次练习---数组

2024-01-02 21:08

本文主要是介绍【C语言答案】第五次练习---数组,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

以下题目是由老师布置的《 谭浩强C程序设计(第四版)》的oj第四次练习题,共五道
使用软件是Devc++5.11。

希望大家抄了作业顺手点个赞,谢谢,爱宁

A. C语言_ex06_01

题目描述

输入:第一行为一个正整数n(1<=n<10)。后边是n行,为nXn个整数矩阵,整数间均以一个空格分隔。要求计算并输出该数组的每行每列之和。
输出格式如下所示,每个整数包含符号占五位,右对齐,两个数之间隔一个空格。行末无空格。测试用例保证所有整数可以用int型存储。

输入样例
3
1 2 3
-4 -5 -6
7 8 9

输出样例
1 2 3 6
-4 -5 -6 -15
7 8 9 24
4 5 6

#include<stdio.h>
int main()
{int n,a[10][10],hangsum[10],liesum[10],i,j;
scanf("%d",&n);for(i=0;i<n;i++)for(j=0;j<n;j++)scanf("%d",&a[i][j]);for(i=0;i<n;i++){hangsum[i]=a[i][0];for(j=1;j<n;j++)hangsum[i]=hangsum[i]+a[i][j];a[i][n]=hangsum[i];}for(j=0;j<n;j++){liesum[j]=a[0][j];for(i=1;i<n;i++)liesum[j]=liesum[j]+a[i][j];}for(i=0;i<n;i++){for(j=0;j<n+1;j++)printf(" %d",a[i][j]);//投机:如果他不让最后有空格就把空格放前面,最前面有空格一般没关系。printf("\n");}	for(j=0;j<n;j++)printf(" %d",liesum[j]);return 0;
}

B. C语言_ex06_03

题目描述

输入:第一行为一个整数n(0<n<10),后边是n行,每行都是一个整数(大于0且小于100,且这n个数各不相同)和一个字符串(长度不超过20,且不包含空格)。最后一行是一个整数m,m为前边n个整数中的一个。
输出只有一行,为整数m后边跟着的那个字符串。

输入样例
2
1 Hello
2 World
2

输出样例
World

#include<stdio.h>
int main(){char s[100][21];int i,n,k,a[100];scanf("%d",&n);for(i=0;i<n;i++)scanf("%d%s",&a[i],s[i]);scanf("%d",&k);for(i=0;i<n;i++)if(a[i]==k)printf("%s\n",s[i]);return 0;
}

C. C语言_ex06_05

题目描述

X公司最近研究出了一种新的编码方式,这种编码是将一串大写字母转化为数字。下面是每个字母所代表的数字。
B, F, P, V 代表 1
C, G, J, K, Q, S, X, Z 代表 2。
D , T 代表 3
L 代表 4
M , N 代表 5
R 代表 6。
另外字母A, E, I, O, U, H, W,Y不代表任何数字。你需要将每个字母转化为所代表的数字,但注意,如果连续几个字母都代表同一个数字,那么你只需要转化成一个数字就可以。比如PF,P和F都代表1,所以你只需要输出一个1,而不是两个1。不代表数字的字母不用转化
输入格式
第一行为整数T(0<T<10)代表T行测试数据,后边是T行,每行为一个只含大写字母的字符串,串长不超过20。
输出格式
为T行,每行对应输入的T行测试数据,为该行测试数据的字符串转化后的数字编码,如果没有任何编码,则输出一个空行。

输入样例
3
KHAWN
PFISTER
BOBBY

输出样例
25
1236
11

# include<stdio.h>
int main()
{int n,i,j,b=0,a[10][21]={};//关键在数组后面这个中括号!!!! char str[10][21];scanf("%d",&n);for(i=0;i<n;i++){scanf("%s",str[i]);//读入第i行字符串 for(j=0;(str[i][j]!='\0');j++){if(str[i][j]=='B'||str[i][j]=='V'||str[i][j]=='F'||str[i][j]=='P')b=1;else{if(str[i][j]=='C'||str[i][j]=='G'||str[i][j]=='J'||str[i][j]=='K'||str[i][j]=='Q'||str[i][j]=='S'||str[i][j]=='X'||str[i][j]=='Z')//C, G, J, K, Q, S, X, Z 代表 2。b=2;else{if(str[i][j]=='D'||str[i][j]=='T')b=3;else{if(str[i][j]=='L')b=4;else{if(str[i][j]=='M'||str[i][j]=='N')b=5;else{if(str[i][j]=='R')b=6;else{if(str[i][j]=='A'||str[i][j]=='E'||str[i][j]=='I'||str[i][j]=='O'||str[i][j]=='U'||str[i][j]=='H'||str[i][j]=='W'||str[i][j]=='Y')//A, E, I, O, U, H, W,Yb=0;}}}}}}a[i][j]=b;}}for(i=0;i<n;i++){for(j=0;j<21;j++){if(a[i][j]!=0&&a[i][j]!=a[i][j+1])printf("%d",a[i][j]);}printf("\n");}return 0;
}

D. C语言_ex06_06

题目描述

输入为一个二进制大整数(大整数大于0,不带符号,无前导0,至少1位数字,且不超过100位数字)。要求将该整数转换成十进制数,并输出。
建议:用字符数组存储大整数。

输入样例
1001001100101100000001011010010

输出样例
1234567890

#include <stdio.h>int main( void )
{char bin[101];scanf( "%s", bin );unsigned long long dec[2] = { 0, 0 }; // base 10^18for( const char* p=bin; *p; ++p ){dec[1] = dec[0]*2/1000000000000000000 + dec[1]*2;dec[0] = dec[0]*2%1000000000000000000 + (*p-'0');}if( dec[1] != 0 )printf( "%llu%018llu\n", dec[1], dec[0] );elseprintf( "%llu\n", dec[0] );
}

E. 回文质数

题目描述

因为151既是一个质数又是一个回文数(从左到右和从右到左是看一样的),所以151是回文质数。请写一个程序来找出范围[a,b] (5≤a≤b≤100000)间的所有回文质数。
输入:只有一行,为两个整数,依次代表a,b 。
输出:每个回文质数输出一行。测试用例保证输入合法且输出至少包含一个回文质数。

输入样例
100 200

输出样例
101
131
151
181
191

#include<stdio.h>#include<math.h>bool c[10000000];int main(){int k,j,a,b,i;scanf("%d%d",&a,&b);if (b>9999999) b=9999999;for (i=2;i<=int (sqrt(b));i++)if (!c[i])for (j=i*i;j<=b;j=j+i)c[j]=1;for (i=a;i<=b;i++){k=i;j=0;while (k){j=j*10+k%10;k=k/10;}if ((!c[i])&&(i==j))printf("%d\n",i);}return 0;}

(日常拖更,宝贝们加油oj)

这篇关于【C语言答案】第五次练习---数组的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/563650

相关文章

hdu2241(二分+合并数组)

题意:判断是否存在a+b+c = x,a,b,c分别属于集合A,B,C 如果用暴力会超时,所以这里用到了数组合并,将b,c数组合并成d,d数组存的是b,c数组元素的和,然后对d数组进行二分就可以了 代码如下(附注释): #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<que

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

hdu 1166 敌兵布阵(树状数组 or 线段树)

题意是求一个线段的和,在线段上可以进行加减的修改。 树状数组的模板题。 代码: #include <stdio.h>#include <string.h>const int maxn = 50000 + 1;int c[maxn];int n;int lowbit(int x){return x & -x;}void add(int x, int num){while

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

poj 3104 二分答案

题意: n件湿度为num的衣服,每秒钟自己可以蒸发掉1个湿度。 然而如果使用了暖炉,每秒可以烧掉k个湿度,但不计算蒸发了。 现在问这么多的衣服,怎么烧事件最短。 解析: 二分答案咯。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <c

RabbitMQ练习(AMQP 0-9-1 Overview)

1、What is AMQP 0-9-1 AMQP 0-9-1(高级消息队列协议)是一种网络协议,它允许遵从该协议的客户端(Publisher或者Consumer)应用程序与遵从该协议的消息中间件代理(Broker,如RabbitMQ)进行通信。 AMQP 0-9-1模型的核心概念包括消息发布者(producers/publisher)、消息(messages)、交换机(exchanges)、

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

如何确定 Go 语言中 HTTP 连接池的最佳参数?

确定 Go 语言中 HTTP 连接池的最佳参数可以通过以下几种方式: 一、分析应用场景和需求 并发请求量: 确定应用程序在特定时间段内可能同时发起的 HTTP 请求数量。如果并发请求量很高,需要设置较大的连接池参数以满足需求。例如,对于一个高并发的 Web 服务,可能同时有数百个请求在处理,此时需要较大的连接池大小。可以通过压力测试工具模拟高并发场景,观察系统在不同并发请求下的性能表现,从而

C语言:柔性数组

数组定义 柔性数组 err int arr[0] = {0}; // ERROR 柔性数组 // 常见struct Test{int len;char arr[1024];} // 柔性数组struct Test{int len;char arr[0];}struct Test *t;t = malloc(sizeof(Test) + 11);strcpy(t->arr,