task03

题目: 现在给出你一些数,要求你写出一个程序,输出这些整数相邻最近的素数,并输出其相距长度。如果左右有等距离长度素数,则输出左侧的值及相应距离。

如果输入的整数本身就是素数,则输出该素数本身,距离输出0


思考:关键点(1)循环给出这些数字输入

(2)判断素数

(3)if判断两点距离


代码

#include<stdio.h>


#include<math.h>


int isprime(int n)


{


   int i,k=(int)sqrt(1.0*n);


   for(i=2;i<=k;i++) 


    if(n%i==0) return 0;


 return 1;


}


void main()


{


 int i,j,n,m,min[10000],mindiff[10000];


    scanf("%d",&n);


 for(i=0;i<n;i++)


 {


  scanf("%d",&m);


  min[i]=0;


  for(j=m;j>=0;j--)


           if(isprime(j)) break;


        min[i]=j;


  mindiff[i]=m-min[i];


  for(j=m;1;j++)


   if(isprime(j)) break;


   if(mindiff[i]>j-m) {


    mindiff[i]=j-m;


    min[i]=j;


   }


 }


    for(i=0;i<n;i++)


  printf("%d %d\n",min[i],mindiff[i]);


}


2065302zhandoudeiji素数距离问题Accepted208240C/C++06-22 18:43:01

/* USER CODE BEGIN Header */ /** ****************************************************************************** * File Name : freertos.c * Description : Code for freertos applications ****************************************************************************** * @attention * * <h2><center>© Copyright (c) 2025 STMicroelectronics. * All rights reserved.</center></h2> * * This software component is licensed by ST under Ultimate Liberty license * SLA0044, the "License"; You may not use this file except in compliance with * the License. You may obtain a copy of the License at: * www.st.com/SLA0044 * ****************************************************************************** */ /* USER CODE END Header */ /* Includes ------------------------------------------------------------------*/ #include "FreeRTOS.h" #include "task.h" #include "main.h" #include "cmsis_os.h" /* Private includes ----------------------------------------------------------*/ /* USER CODE BEGIN Includes */ #include"stdio.h" #include"usart.h" /* USER CODE END Includes */ /* Private typedef -----------------------------------------------------------*/ /* USER CODE BEGIN PTD */ typedef struct { uint32_t var1; uint32_t var2; uint32_t var3; }DataGroup; /* USER CODE END PTD */ /* Private define ------------------------------------------------------------*/ /* USER CODE BEGIN PD */ /* USER CODE END PD */ /* Private macro -------------------------------------------------------------*/ /* USER CODE BEGIN PM */ /* USER CODE END PM */ /* Private variables ---------------------------------------------------------*/ /* USER CODE BEGIN Variables */ /* USER CODE END Variables */ osThreadId Task_KEYHandle; osThreadId myTask01Handle; osThreadId myTask02Handle; osThreadId myTask03Handle; osMessageQId myQueue01Handle; /* Private function prototypes -----------------------------------------------*/ /* USER CODE BEGIN FunctionPrototypes */ /* USER CODE END FunctionPrototypes */ void StartTask_KEY(void const * argument); void StartTask01(void const * argument); void StartTask02(void const * argument); void StartTask03(void const * argument); void MX_FREERTOS_Init(void); /* (MISRA C 2004 rule 8.1) */ /* GetIdleTaskMemory prototype (linked to static allocation support) */ void vApplicationGetIdleTaskMemory( StaticTask_t **ppxIdleTaskTCBBuffer, StackType_t **ppxIdleTaskStackBuffer, uint32_t *pulIdleTaskStackSize ); /* USER CODE BEGIN GET_IDLE_TASK_MEMORY */ static StaticTask_t xIdleTaskTCBBuffer; static StackType_t xIdleStack[configMINIMAL_STACK_SIZE]; void vApplicationGetIdleTaskMemory( StaticTask_t **ppxIdleTaskTCBBuffer, StackType_t **ppxIdleTaskStackBuffer, uint32_t *pulIdleTaskStackSize ) { *ppxIdleTaskTCBBuffer = &xIdleTaskTCBBuffer; *ppxIdleTaskStackBuffer = &xIdleStack[0]; *pulIdleTaskStackSize = configMINIMAL_STACK_SIZE; /* place for user code */ } /* USER CODE END GET_IDLE_TASK_MEMORY */ /** * @brief FreeRTOS initialization * @param None * @retval None */ void MX_FREERTOS_Init(void) { /* USER CODE BEGIN Init */ /* USER CODE END Init */ /* USER CODE BEGIN RTOS_MUTEX */ /* add mutexes, ... */ /* USER CODE END RTOS_MUTEX */ /* USER CODE BEGIN RTOS_SEMAPHORES */ /* add semaphores, ... */ /* USER CODE END RTOS_SEMAPHORES */ /* USER CODE BEGIN RTOS_TIMERS */ /* start timers, add new ones, ... */ /* USER CODE END RTOS_TIMERS */ /* Create the queue(s) */ /* definition and creation of myQueue01 */ osMessageQDef(myQueue01, 16, uint32_t); myQueue01Handle = osMessageCreate(osMessageQ(myQueue01), NULL); /* USER CODE BEGIN RTOS_QUEUES */ /* add queues, ... */ /* USER CODE END RTOS_QUEUES */ /* Create the thread(s) */ /* definition and creation of Task_KEY */ osThreadDef(Task_KEY, StartTask_KEY, osPriorityNormal, 0, 128); Task_KEYHandle = osThreadCreate(osThread(Task_KEY), NULL); /* definition and creation of myTask01 */ osThreadDef(myTask01, StartTask01, osPriorityIdle, 0, 128); myTask01Handle = osThreadCreate(osThread(myTask01), NULL); /* definition and creation of myTask02 */ osThreadDef(myTask02, StartTask02, osPriorityIdle, 0, 128); myTask02Handle = osThreadCreate(osThread(myTask02), NULL); /* definition and creation of myTask03 */ osThreadDef(myTask03, StartTask03, osPriorityIdle, 0, 128); myTask03Handle = osThreadCreate(osThread(myTask03), NULL); /* USER CODE BEGIN RTOS_THREADS */ /* add threads, ... */ /* USER CODE END RTOS_THREADS */ } /* USER CODE BEGIN Header_StartTask_KEY */ /** * @brief Function implementing the Task_KEY thread. * @param argument: Not used * @retval None */ /* USER CODE END Header_StartTask_KEY */ void StartTask_KEY(void const * argument) { /* USER CODE BEGIN StartTask_KEY */ /* Infinite loop */ uint32_t ProducerValue=0; DataGroup myDataGroup_t={10,20,30}; ProducerValue=(uint32_t)&myDataGroup_t; for(;;) { if(HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_13)==0) { osDelay(10); if(HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_13)==0) { if(osMessagePut(myQueue01Handle,ProducerValue,100)!=osOK) { osThreadSuspendAll(); printf("send fail!\r\n"); osThreadResumeAll(); } else { printf("send success!\r\n"); osThreadResumeAll(); } while(HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_13)==0) { osDelay(10); } } } osDelay(1); } /* USER CODE END StartTask_KEY */ } /* USER CODE BEGIN Header_StartTask01 */ /** * @brief Function implementing the myTask01 thread. * @param argument: Not used * @retval None */ /* USER CODE END Header_StartTask01 */ void StartTask01(void const * argument) { /* USER CODE BEGIN StartTask01 */ /* Infinite loop */ osEvent event; DataGroup *myDataGroup_r; for(;;) { event=osMessageGet(myQueue01Handle,osWaitForever); if(event.status==osEventMessage) { myDataGroup_r=event.value.p; osThreadSuspendAll(); printf("va1 is %d\r\n",myDataGroup_r->var1); printf("va2 is %d\r\n",myDataGroup_r->var2); printf("va3 is %d\r\n",myDataGroup_r->var3); osThreadResumeAll(); } osDelay(1); } /* USER CODE END StartTask01 */ } /* USER CODE BEGIN Header_StartTask02 */ /** * @brief Function implementing the myTask02 thread. * @param argument: Not used * @retval None */ /* USER CODE END Header_StartTask02 */ void StartTask02(void const * argument) { /* USER CODE BEGIN StartTask02 */ /* Infinite loop */ osEvent event; DataGroup *myDataGroup_r; for(;;) { event=osMessageGet(myQueue01Handle,osWaitForever); if(event.status==osEventMessage) { myDataGroup_r=event.value.p; osThreadSuspendAll(); printf("var1 is %d\r\n",myDataGroup_r->var1); printf("var2 is %d\r\n",myDataGroup_r->var2); printf("var3 is %d\r\n",myDataGroup_r->var3); osThreadResumeAll(); } osDelay(1); } /* USER CODE END StartTask02 */ } /* USER CODE BEGIN Header_StartTask03 */ /** * @brief Function implementing the myTask03 thread. * @param argument: Not used * @retval None */ /* USER CODE END Header_StartTask03 */ void StartTask03(void const * argument) { /* USER CODE BEGIN StartTask03 */ /* Infinite loop */ for(;;) { osDelay(1); } /* USER CODE END StartTask03 */ } /* Private application code --------------------------------------------------*/ /* USER CODE BEGIN Application */ /* USER CODE END Application */ /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ myTask03可以怎么写
06-07
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值